博客
关于我
【 文件读写 】简单C/C++文件读写代码示例—— FILE 指针和 fstream 流文件
阅读量:203 次
发布时间:2019-02-28

本文共 1716 字,大约阅读时间需要 5 分钟。

在文件操作中,C++ 和 C 都提供了丰富的 IO 接口,能够满足不同场景下的需求。本文将从 C++ 和 C 的实现细节入手,分析文件读写的实现方法及其适用场景。

C++ 文件操作

C++ 提供了高效的文件读写接口,主要通过 fstream 类来操作文件。以下是常用的操作方法:

#include 
#include
#include
using namespace std;int main() { // 示例代码 fstream fin, fout; fin.open("FileIO.txt", ios::in); fout.open("FileIOcpp.txt", ios::out); string s; // 逐个字符读取 cout << "逐str读取:" << endl; while (!fin.eof()) { fin >> s; cout << s << endl; fout << s << endl; } // 按行读取 fin.close(); fin.open("FileIO.txt", ios::in); cout << "按行读取:" << endl; while (getline(fin, s)) { cout << s << endl; }}

C 文件操作

在 C 中,文件操作主要通过 stdio.h 库来实现。以下是常见的文件操作示例:

#include 
#include
#include
int main() { // 示例代码 FILE *fpIn = fopen("FileIO.txt", "r"); FILE *fpOut = fopen("FileIOc.txt", "w"); // 读取整个文件内容 fseek(fpIn, 0, SEEK_END); long lsize = ftell(fpIn); fseek(fpIn, 0, SEEK_SET); char *str = (char *)malloc((lsize + 1) * sizeof(char)); fread(str, sizeof(char), lsize, fpIn); printf("一次读取:\n%s\n", str); // 逐行读取 printf("逐str读取:\n"); while (!feof(fpIn)) { fscanf(fpIn, "%s", str); printf("%s\n", str); fprintf(fpOut, "%s\n", str); } // 按行读取所有内容 printf("逐行读取:\n"); while (!feof(fpIn)) { fgets(str, lsize + 1, fpIn); printf("%s\n", str); } free(str); fclose(fpIn); fclose(fpOut); return 0;}

文件操作的异同

C++ 和 C 在文件操作上虽然有所不同,但都能满足基本需求。C++ 的 fstream 类提供了更高级别的接口,能够以更简便的方式操作文件。而 C 的 stdio 库则更为基础,操作稍微复杂一些。选择哪种方式主要取决于项目的需求和个人偏好。

总结

无论是 C++ 还是 C,文件操作都是日常编程中常用的技能。掌握这些接口能够显著提升代码的灵活性和效率。通过合理选择和优化,任何编程语言都能在文件操作方面表现出色。

转载地址:http://wjvi.baihongyu.com/

你可能感兴趣的文章
Pandas数据结构之DataFrame常见操作
查看>>
pandas整合多份csv文件
查看>>
pandas某一列转数组list
查看>>
Pandas模块,我觉得掌握这些就够用了!
查看>>
Pandas玩转文本处理!
查看>>
SpringBoot 整合 Mybatis Plus 实现基本CRUD功能
查看>>
pandas的to_sql方法中使用if_exists=‘replace‘
查看>>
Springboot ppt转pdf——aspose方式
查看>>
pandas读取csv编码utf-8报错
查看>>
pandas读取parquet报错
查看>>
pandas读取数据用来深度学习
查看>>
pandas读取文件时,不去掉前面的0 保留原有的数据格式
查看>>
Pandas进阶大神!从0到100你只差这篇文章!
查看>>
spring5-介绍Spring框架
查看>>
pandas,python - 如何在时间序列中选择特定时间
查看>>
Spring 框架之 AOP 原理深度剖析
查看>>
Pandas:如何按列元素的组合分组,以指示基于不同列的值的同现?
查看>>
Pandas:将一列与数据帧的所有其他列进行比较
查看>>
PANDA和GLOB:将文件夹中的所有xlsx文件转换为CSV类型错误:__init__()获得意外的关键字参数‘;xfid‘;
查看>>
panda查找想要找的行合并成一个新pd
查看>>