C 程序设计文件操作核心知识点梳理
文件操作是 C 语言实现 “数据持久化” 的核心能力能将程序中的数据写入磁盘文件或从磁盘文件读取数据到程序中是编程考核中综合应用的高频考点。本文从文件操作基础、文件的打开与关闭、文件的读写操作、文件定位与进阶操作四大维度系统梳理文件操作的语法规则、核心考点、易错点及实战应用。一、文件操作基础核心概念与分类1. 文件的核心概念文件存储在外部存储介质如磁盘上的一组相关数据的集合程序运行时的数据默认在内存中退出后丢失文件操作可将数据永久保存文件指针C 语言通过FILE类型指针文件指针管理文件FILE是系统定义的结构体包含文件描述符、缓冲区地址、读写位置等信息标准文件指针系统默认打开的 3 个文件指针无需手动打开stdin标准输入键盘stdout标准输出屏幕stderr标准错误屏幕。2. 文件的分类按存储形式类型存储形式特点示例文本文件以 ASCII 码存储可直接用记事本打开可读性高占用空间稍大.txt、.c、.h文件二进制文件以二进制数据存储不可直接阅读存储高效占用空间小.exe、.jpg、.dat文件二、文件的打开与关闭基础操作1. 核心函数需引入stdio.h文件操作的第一步是 “打开文件”最后一步是 “关闭文件”核心函数为fopen()和fclose()。1文件打开fopen()语法FILE *fopen(const char *filename, const char *mode);参数说明filename文件路径 文件名如data.txt、D:/test.datmode打开模式核心考点决定文件的操作权限。返回值成功返回文件指针失败返回NULL需检查返回值避免空指针操作。2文件打开模式高频考点模式适用文件类型功能说明注意事项r文本文件只读文件必须存在文件不存在则打开失败w文本文件只写文件不存在则创建存在则清空原有内容会覆盖原有数据a文本文件追加写文件不存在则创建写入数据追加到文件末尾不覆盖原有数据r文本文件读写文件必须存在可同时读和写w文本文件读写文件不存在则创建存在则清空先清空再读写a文本文件读写文件不存在则创建写入追加到末尾读从开头写从末尾rb/wb/ab二进制文件对应二进制文件的只读 / 只写 / 追加操作二进制数据时使用3文件关闭fclose()语法int fclose(FILE *fp);功能关闭文件指针指向的文件释放文件缓冲区和相关资源返回值成功返回 0失败返回EOFEOF 是宏值为 - 1注意文件使用完毕必须关闭否则可能导致数据丢失缓冲区数据未写入磁盘。2. 基础示例文件的打开与关闭#include stdio.h int main() { // 打开文件以只写模式打开data.txt FILE *fp fopen(data.txt, w); // 检查文件是否打开成功核心易错点忽略NULL判断 if (fp NULL) { perror(文件打开失败); // 打印错误原因如权限不足、路径不存在 return 1; // 异常退出 } printf(文件打开成功\n); // 关闭文件 if (fclose(fp) ! 0) { perror(文件关闭失败); return 1; } printf(文件关闭成功\n); return 0; }三、文件的读写操作核心考点文件打开后核心操作是 “读”从文件到程序和 “写”从程序到文件分为文本文件读写和二进制文件读写两类。1. 文本文件的读写操作1字符读写fputc()/fgetc()单个字符fputc(int ch, FILE *fp)将字符ch写入fp指向的文件成功返回写入的字符失败返回EOFfgetc(FILE *fp)从fp指向的文件读取一个字符成功返回字符的 ASCII 码失败 / 到文件末尾返回EOF。示例文本文件字符读写#include stdio.h int main() { FILE *fp; char ch; // 1. 写入字符到文件 fp fopen(text.txt, w); if (fp NULL) { perror(写入文件打开失败); return 1; } // 写入字符串hello逐个字符 char str[] hello; for (int i 0; str[i] ! \0; i) { fputc(str[i], fp); } fclose(fp); // 2. 从文件读取字符并输出 fp fopen(text.txt, r); if (fp NULL) { perror(读取文件打开失败); return 1; } // 循环读取直到文件末尾fgetc返回EOF while ((ch fgetc(fp)) ! EOF) { printf(%c, ch); // 输出hello } fclose(fp); return 0; }2字符串读写fputs()/fgets()整行字符串fputs(const char *str, FILE *fp)将字符串str写入文件不自动加换行符成功返回非负数失败返回EOFfgets(char *str, int n, FILE *fp)从文件读取最多n-1个字符到str遇到换行 / 文件末尾 / 满n-1个字符停止自动在末尾加\0成功返回str失败 / 到末尾返回NULL。示例文本文件字符串读写#include stdio.h int main() { FILE *fp; char buf[100]; // 存储读取的字符串 // 1. 写入多行字符串 fp fopen(text.txt, w); if (fp NULL) { perror(写入失败); return 1; } fputs(Hello World\n, fp); // 手动加换行符 fputs(C语言文件操作\n, fp); fclose(fp); // 2. 逐行读取并输出 fp fopen(text.txt, r); if (fp NULL) { perror(读取失败); return 1; } // fgets读取到NULL表示文件末尾 while (fgets(buf, 100, fp) ! NULL) { printf(%s, buf); // 输出两行内容 } fclose(fp); return 0; }3格式化读写fprintf()/fscanf()按格式读写fprintf(FILE *fp, const char *format, ...)按格式将数据写入文件类似printf但输出到文件fscanf(FILE *fp, const char *format, ...)按格式从文件读取数据类似scanf但输入来自文件。示例格式化读写结构体数据核心应用#include stdio.h // 定义学生结构体 struct Student { int id; char name[20]; double score; }; int main() { FILE *fp; struct Student stu1 {101, Zhang San, 92.5}; struct Student stu2; // 存储读取的学生数据 // 1. 格式化写入文件 fp fopen(student.txt, w); if (fp NULL) { perror(写入失败); return 1; } fprintf(fp, %d %s %.1f, stu1.id, stu1.name, stu1.score); fclose(fp); // 2. 格式化读取文件 fp fopen(student.txt, r); if (fp NULL) { perror(读取失败); return 1; } fscanf(fp, %d %s %lf, stu2.id, stu2.name, stu2.score); printf(学号%d姓名%s成绩%.1f\n, stu2.id, stu2.name, stu2.score); fclose(fp); return 0; }%d匹配整型stu2.id是 int 类型变量的地址匹配正确%s匹配字符串stu2.name是字符数组名本质是地址无需加匹配正确%lf匹配双精度浮点型stu2.score是 double 类型变量的地址匹配正确注意读取 double 必须用%lf写入用%f或%lf均可。2. 二进制文件的读写操作二进制文件读写使用fwrite()和fread()直接操作内存中的二进制数据效率更高适用于存储结构体、数组等复杂数据。1二进制写入fwrite()语法size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *fp);参数说明ptr待写入数据的地址size单个数据的字节数nmemb要写入的数据个数fp文件指针。返回值成功写入的数据个数失败则小于nmemb。2二进制读取fread()语法size_t fread(void *ptr, size_t size, size_t nmemb, FILE *fp);参数说明与fwrite一致ptr为存储读取数据的地址返回值成功读取的数据个数到文件末尾则返回 0。示例二进制读写结构体数组#include stdio.h struct Student { int id; char name[20]; double score; }; int main() { FILE *fp; // 定义并初始化结构体数组 struct Student stus[2] { {101, Zhang San, 92.5}, {102, Li Si, 88.0} }; struct Student stus_read[2]; // 存储读取的数据 // 1. 二进制写入文件 fp fopen(student.dat, wb); if (fp NULL) { perror(写入失败); return 1; } // 写入2个Student类型数据每个占sizeof(struct Student)字节 fwrite(stus, sizeof(struct Student), 2, fp); fclose(fp); // 2. 二进制读取文件 fp fopen(student.dat, rb); if (fp NULL) { perror(读取失败); return 1; } // 读取2个Student类型数据 fread(stus_read, sizeof(struct Student), 2, fp); // 输出读取结果 for (int i 0; i 2; i) { printf(第%d个学生学号%d姓名%s成绩%.1f\n, i1, stus_read[i].id, stus_read[i].name, stus_read[i].score); } fclose(fp); return 0; }四、文位与进阶操作高频考点文件读写时系统会维护一个 “文件位置指针”指向当前读写的位置默认从文件开头开始可通过定位函数修改读写位置。1. 文件定位核心函数1fseek()移动文件位置指针语法int fseek(FILE *fp, long offset, int origin);参数说明offset偏移量正数向后移负数向前移origin偏移起始位置宏定义SEEK_SET文件开头0SEEK_CUR当前位置1SEEK_END文件末尾2。返回值成功返回 0失败返回非 0。2ftell()获取当前文件位置指针的偏移量语法long ftell(FILE *fp);返回值成功返回偏移量字节数失败返回 - 1L。3rewind()将文件位置指针重置到文件开头语法void rewind(FILE *fp);2. 示例文件定位与文件长度计算#include stdio.h int main() { FILE *fp fopen(text.txt, r); if (fp NULL) { perror(打开失败); return 1; } // 1. 计算文件长度字节数 fseek(fp, 0, SEEK_END); // 指针移到文件末尾 long len ftell(fp); // 获取末尾偏移量即文件长度 printf(文件长度%ld 字节\n, len); // 2. 重置指针到开头读取第一个字符 rewind(fp); char ch fgetc(fp); printf(文件第一个字符%c\n, ch); // 3. 指针向后偏移5个字节读取字符 fseek(fp, 5, SEEK_SET); ch fgetc(fp); printf(偏移5字节后的字符%c\n, ch); fclose(fp); return 0; }3. 文件操作的错误处理ferror(FILE *fp)检查文件操作是否出错出错返回非 0否则返回 0clearerr(FILE *fp)清除文件的错误标志和文件末尾标志。示例错误检查#include stdio.h int main() { FILE *fp fopen(none.txt, r); // 不存在的文件 if (fp NULL) { perror(打开失败); return 1; } char ch fgetc(fp); if (ferror(fp)) { // 检查读取是否出错 printf(文件读取出错\n); clearerr(fp); // 清除错误标志 } fclose(fp); return 0; }五、文件操作核心考点与易错点汇总1. 高频考点文件的打开与关闭fopen的打开模式r/w/a/rb/wbfclose的必要性文本文件读写fprintf/fscanf、fputs/fgets的使用结构体数据的格式化读写二进制文件读写fwrite/fread的参数含义复杂数据的二进制存储文件定位fseek/ftell/rewind的使用文件长度计算错误处理fopen返回NULL的判断perror的使用。2. 核心易错点忽略fopen返回值检查文件打开失败如路径错误、权限不足时直接使用NULL指针导致程序崩溃打开模式错误如用r模式打开不存在的文件用w模式打开需保留数据的文件会清空文本文件与二进制文件混淆用fscanf读取二进制文件或用fread读取文本文件导致数据错误忘记关闭文件导致缓冲区数据未写入磁盘或文件句柄泄漏fgets读取换行符fgets会将文件中的换行符读入字符串输出时可能出现多余空行二进制读写的参数错误fwrite/fread的size或nmemb写反导致数据读写异常。总结文件操作的核心流程fopen打开 → 读写操作 →fclose关闭必须检查fopen的返回值文本文件适用于可读数据用fprintf/fscanf/fputs/fgets二进制文件适用于高效存储用fwrite/fread文件位置指针是读写位置的核心fseek可灵活修改读写位置ftell可计算文件长度易错点核心避坑检查打开结果、选对打开模式、用完关闭文件、区分文本 / 二进制读写。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2429796.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!