• 【文件操作API的使用】


    1.概念

    这对聪明的你们来说简直就是,对吗。

    那什么是文件操作符,文件操作又有哪些步骤呢?

    文件操作符通常用于指代在计算机编程中用于处理文件的特殊符号或标识符。在很多编程语言中,文件操作符被用于打开、关闭、读取和写入文件,以及对文件进行其他操作。

    一般来说,文件操作有以下步骤:

    1. 打开文件:使用文件操作符可以打开一个文件,使得程序能够访问文件的内容。通常情况下,打开文件需要提供文件名、路径以及访问模式等信息。

    2. 关闭文件:在文件使用完毕后,应该及时关闭文件,释放文件相关的资源。关闭文件可以通过文件操作符完成。

    3. 读取文件:文件操作符可以用于从文件中读取数据。读取文件时,文件操作符会根据指定的位置读取特定数量的数据,并将数据传递给程序进行处理。

    4. 写入文件:除了读取文件外,文件操作符也可以用于向文件中写入数据。程序可以使用文件操作符将数据写入文件的指定位置。

    5. 移动文件指针:文件操作符还可以用于移动文件指针的位置。文件指针表示了当前读取或写入位置在文件中的偏移量。通过移动文件指针,程序可以在文件中进行定位读取或写入操作。

    在不同的编程语言和操作系统中,文件操作符的具体实现方式可能会有所不同。
    例如,在C语言中,文件操作符通常是通过使用 FILE 结构体和相关的函数来实现的。
    而在Python等高级语言中,文件操作符则可能是通过内置的文件对象来实现的。

    今天我们就以C语言为例

    2.C语言文件操作的api介绍

    fopen和fclose

    1. fopen() 是一个用于在C语言中打开文件的标准库函数。
    2. 它通常用于打开一个文件,并返回一个指向该文件的文件指针。
    3. fopen() 函数具有以下一般形式:
    4. FILE *fopen(const char *filename, const char *mode);
    5. 其中:
    6. 参数1:filename:要打开的文件的路径。
    7. 参数2mode:打开文件的模式,可以是以下之一:
    8. "r":只读模式。文件必须存在,否则函数失败。
    9. "w":写入模式。如果文件存在,则文件内容被清空,如果文件不存在,则创建新文件。
    10. "a":追加模式。如果文件存在,写入的数据将被追加到文件末尾,如果文件不存在,则创建新文件。
    11. "r+":读写模式。文件必须存在,文件的内容可以被读取和写入。
    12. "w+":读写模式。如果文件存在,则文件内容被清空,如果文件不存在,则创建新文件。
    13. "a+":读写模式。如果文件存在,写入的数据将被追加到文件末尾,如果文件不存在,则创建新文件。
    14. 函数返回一个指向文件的指针,如果打开文件失败,则返回 NULL
    15. close() 函数用于关闭一个已打开的文件。关闭文件后,释放与该文件相关的所有资源,
    16. 并将文件指针指向 NULL。它的一般形式如下:
    17. int fclose(FILE *stream);
    18. 其中:
    19. stream:指向已经被 fopen() 打开的文件的指针。
    20. 函数返回值为 0 表示成功关闭文件,返回 EOF 表示关闭文件失败

    当然,我们还有其他的打开方式

     

     fgetc和fputc

    1. fgetc() 和 fputc() 是用于在 C 语言中进行文件读写操作的标准库函数。
    2. fgetc()
    3. fgetc() 函数用于从指定的文件中读取一个字符,并将文件指针向前移动到下一个字符位置。
    4. 它的一般形式如下:
    5. int fgetc(FILE *stream);
    6. 其中:
    7. stream:指向已经被 fopen() 打开的文件的指针。
    8. 函数返回值是读取的字符,如果到达文件结尾或者出现错误,
    9. 则返回 EOF(表示 End Of File)。
    10. fputc()
    11. fputc() 函数用于向指定的文件中写入一个字符,并将文件指针向前移动到下一个字符位置。
    12. 它的一般形式如下:
    13. int fputc(int character, FILE *stream);
    14. 其中:
    15. character:要写入的字符。
    16. stream:指向已经被 fopen() 打开的文件的指针。
    17. 函数返回成功写入的字符,如果出现错误,则返回 EOF。

    介绍了这两个,那我们就可以写一个函数测试一下喽

     fputs和fgets

    显而易见了吧,我们只有一个字母的区别,而且‘s’很明显,就是字符串喽

    1. fgets() 函数用于从指定的文件流中读取一行,并将其存储在字符串中。它的一般形式如下:
    2. char *fgets(char *str, int num, FILE *stream);
    3. 其中:
    4. str:是一个指向字符数组的指针,用于存储读取的字符串。
    5. num:是要读取的最大字符数(包括空字符 \0)。
    6. stream:是一个指向 FILE 对象的指针,它指定了要读取的文件流。
    7. 函数返回指向存储字符串的指针,如果到达文件末尾或者出现错误,则返回 NULL
    8. fputs() 函数用于将一个字符串写入到指定的文件流中。它的一般形式如下:
    9. int fputs(const char *str, FILE *stream);
    10. 其中:
    11. str:是一个指向要写入的字符串的指针。
    12. stream:是一个指向 FILE 对象的指针,它指定了要写入的文件流。
    13. 函数返回非负值表示成功,返回 EOF 表示写入失败。

     

    fprintf和fscanf

    前面我们说到的均为输入输出流( fgetc和fputc, fputs和fgets)而这个尾格式化输入输出流(fprintf和fscanf

    1. fprintf() 和 fscanf() 是 C 语言中用于文件操作的函数,
    2. 它们与 printf() 和 scanf() 函数非常类似,但是它们从文件流中读取或写入数据。
    3. fprintf() 函数用于将格式化数据写入到文件中。它的一般形式如下:
    4. int fprintf(FILE *stream, const char *format, ...);
    5. 其中:
    6. stream 是一个指向 FILE 对象的指针,它指定了要写入的文件流。
    7. format 是一个字符串,包含了要写入到文件中的文本以及格式化指示符。
    8. ... 是要写入到文件的数据,可以是变量列表。
    9. fprintf() 函数的返回值是成功写入到文件中的字符数,如果发生错误,则返回一个负值。
    10. fscanf() 函数用于从文件中读取格式化数据。它的一般形式如下:
    11. int fscanf(FILE *stream, const char *format, ...);
    12. 其中:
    13. stream 是一个指向 FILE 对象的指针,它指定了要读取的文件流。
    14. format 是一个字符串,包含了要读取的数据的格式化指示符。
    15. ... 是用于接收读取的数据的变量列表。
    16. fscanf() 函数的返回值是成功读取到的变量数,如果到达文件末尾或者发生错误,则返回 EOF。

    fread和fwrite(用于二进制文件的读写操作) 

    1. fread() 和 fwrite() 是 C 语言中用于文件操作的函数,它们与 fprintf() 和 fscanf() 类似,
    2. 但是它们用于二进制文件的读写操作。
    3. fwrite() 函数用于将数据块以二进制形式写入到文件中。它的一般形式如下:
    4. size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);
    5. 其中:
    6. ptr 是一个指向要写入的数据块的指针。
    7. size 是每个数据块的大小(以字节为单位)。
    8. nmemb 是要写入的数据块的数量。
    9. stream 是一个指向 FILE 对象的指针,它指定了要写入的文件流。
    10. fwrite() 函数的返回值是成功写入的数据块数量,如果发生错误,则返回一个小于 nmemb 的值。
    11. fread() 函数用于从二进制文件中读取数据块。它的一般形式如下:
    12. size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
    13. 其中:
    14. ptr 是一个指向用于存储读取数据的缓冲区的指针。
    15. size 是每个数据块的大小(以字节为单位)。
    16. nmemb 是要读取的数据块的数量。
    17. stream 是一个指向 FILE 对象的指针,它指定了要读取的文件流。
    18. fread() 函数的返回值是成功读取的数据块数量,如果到达文件末尾或者发生错误,
    19. 则返回一个小于 nmemb 的值。

     feof和ferror

    1. `feof``ferror` 都是用于检查文件流状态的函数,但有一些区别:
    2. 1. `feof(FILE *stream)` 函数用于检查给定文件流 `stream` 是否已经到达文件末尾。
    3. 当文件流到达文件末尾时,`feof` 返回非零值;否则,返回 0。
    4. 2. `ferror(FILE *stream)` 函数用于检查给定文件流 `stream` 的错误标志是否被设置。
    5. 如果文件流 `stream` 的错误标志被设置,`ferror` 返回非零值;否则,返回 0。
    6. 在使用这两个函数时,应当注意它们的返回值不是绝对的,需要结合其他函数一起使用,
    7. 比如 `fgets``fscanf``fread``fwrite` 等读写函数,
    8. 检查它们的返回值以及 `feof``ferror` 的返回值,以正确处理文件流状态和错误。

     3,每期一问

    正确的使用feof和ferror

  • 相关阅读:
    Vue2 零基础入门 Vue2 零基础入门第五天 5.3 自定义指令
    Spring事务
    使用cpolar远程连接群晖NAS(升级安全链接1)
    51单片机实验03-定时器T0来实现流水灯从左到右再从右到左
    [极客大挑战 2019]Http1
    Vite: 双构建引擎- Esbuild和Rollup
    Redis详解
    广州华锐互动VRAR:VR教学楼地震模拟体验增强学生防震减灾意识
    【普通人题解】LeetCode174. 地下城游戏
    linux网桥简单理解和持久化配置
  • 原文地址:https://blog.csdn.net/HH_KZ1314/article/details/137267958