博客
关于我
【 文件读写 】简单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/

你可能感兴趣的文章
OpenCV与AI深度学习 | 基于Python和OpenCV将图像转为ASCII艺术效果
查看>>
OpenCV与AI深度学习 | 基于PyTorch实现Faster RCNN目标检测
查看>>
OpenCV与AI深度学习 | 基于PyTorch语义分割实现洪水识别(数据集 + 源码)
查看>>
OpenCV与AI深度学习 | 基于YOLO11的车体部件检测与分割
查看>>
OpenCV与AI深度学习 | 基于YoloV11自定义数据集实现车辆事故检测(有源码,建议收藏!)
查看>>
OpenCV与AI深度学习 | 基于YOLOv8 + BotSORT实现球员和足球检测与跟踪 (步骤 + 源码)
查看>>
OpenCV与AI深度学习 | 基于YOLOv8实现高级目标检测和区域计数
查看>>
VS2003 Front Page Server Extension
查看>>
OpenCV与AI深度学习 | 基于YOLOv8的停车对齐检测
查看>>
OpenCV与AI深度学习 | 基于YoloV8的药丸/片剂类型识别
查看>>
OpenCV与AI深度学习 | 基于YOLO和EasyOCR从视频中识别车牌
查看>>
OpenCV与AI深度学习 | 基于图像处理的火焰检测算法(颜色+边缘)
查看>>
OpenCV与AI深度学习 | 基于拉普拉斯金字塔实现图像融合(步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 基于改进YOLOv8的景区行人检测算法
查看>>
OpenCV与AI深度学习 | 基于机器视觉的磁瓦表面缺陷检测方案
查看>>
OpenCV与AI深度学习 | 基于深度学习的轮胎缺陷检测系统
查看>>
OpenCV与AI深度学习 | 如何使用YOLO-World做目标检测
查看>>
OpenCV与AI深度学习 | 如何使用YOLOv9分割图像中的对象
查看>>
OpenCV与AI深度学习 | 如何使用YOLOv9检测图片和视频中的目标
查看>>
OpenCV与AI深度学习 | 如何在 Docker 容器中使用 GPU
查看>>