C语言文件操作中 fgets与fputs 函数详解

C语言文件操作中 fgets、fputs 函数详解

先给出api

fgets 
语法: 
 #include <stdio.h>
 char *fgets( char *str, int num, FILE *stream );

函数fgets()从给出的文件流中读取[num - 1]个字符并且把它们转储到str(字符串)中. fgets()在到达行末时停止,在这种情况下,str(字符串)将会被一个新行符结束. 如果fgets()达到[num - 1]个字符或者遇到EOF, str(字符串)将会以null结束.fgets()成功时返回str(字符串),失败时返回NULL.

自己理解

1、每次读取一行,如果读取的一行字符数 len  > bufsize-1,则 buf[ bufsize-1 ] = '0'

       文件句柄指向第bufsize的位置。

2、每次读取一行,如果读取的一行字符数 len = bufsize-1,则 buf[ bufsize-1 ] = '0'

         文件句柄指向第bufsize的位置。

3、每次读取一行,如果读取的一行字符数  len < bufsize-1,则 buf [ len-1 ] = '\n' , buf [ len ] = '\0'

         文件句柄指向下一行的首位置。

验证代码:

int i=0;
 FILE *fp;
 char buff[5];
 //将数组赋值为9,便于后面与赋值的地方比较 
 memset(buff,9,sizeof(buff));
 
 char *fName = "d:/123.txt"; 
 fp = fopen(fName,"r");
 fgets(buff,sizeof(buff),fp);
 
 //打印出数组的ascii码 
 printf("buff数组内容:\n");
 for(i=0;i<sizeof(buff);i++)
 {
 printf("%d ",(int)buff[i]); 
 }
 printf("\n");
 
 //继续获取下一行字符,验证文件句柄的位置
 memset(buff,9,sizeof(buff));
 fgets(buff,sizeof(buff),fp);
 //打印出数组的ascii码 
 printf("下一行buff数组内容:\n");
 for(i=0;i<sizeof(buff);i++)
 {
 printf("%d ",(int)buff[i]); 
 }
 printf("\n");
 
 fclose(fp);

123.txt 文件内容:

1234
asdf

输出结果:

buff长度为4,验证理解1

buff数组内容:

49 50 51 0
下一行buff数组内容:
52 10 0 9
 

buff长度为5,验证理解2

buff数组内容:
49 50 51 52 0
下一行buff数组内容:
10 0 9 9 9

buff长度为10,验证理解3

buff数组内容:

49 50 51 52 10 0 9 9 9 9
下一行buff数组内容:
97 115 100 102 0 9 9 9 9 9

 文件写入数据本质:

将字符串插入到文件中,在字符串的结尾处插入换行符'\n'

fgets函数本质:

按照需要写入的缓存空间大小,将文件中的buffsize-1个字符写入到缓存空间,将缓存空间的buffsize位置写入'\0'字符。

fputs函数本质:

将指定的字符串写入文件流中,不包含字符串结尾符'\0',利用它可以替换文件流中数据,但是不能添加数据。

验证代码

  FILE *fp;
 char *fName = "d:/123.txt"; 
 fp = fopen(fName,"r+");
 fseek(fp,3,SEEK_CUR);
 fputs("Insert Strings",fp);
 fclose(fp);

原文件内容:

1234
Second Line. Second Strings.

修改后文件内容:

123Insert Strings. Second Strings.

可以看出,将原文件中的“\n及Second Line.” 替换为了“Insert Strings.”

fputc函数本质:

函数fputc()把给出的字符ch写到给出的输出流中的指定位置. 返回值是字符, 发生错误时返回值是EOF. 可以替换文件流中数据,但是不能添加数据。

fgetc函数本质:

fgetc()函数返回来自stream(流)中的下一个字符,如果到达文件尾或者发生错误时返回EOF. 是什么字符,就返回什么字符(包括'\0','\n')。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!