函数所在头文件:stdio.h
说明:前半部分主要为对各个文件流操作函数的例举,后半部分着重于上机运行分析。文中部分引用自王桂林老师的C/C++课件。
1.FIELE *fopen(const char*filename,const char *mode)
以mode的方式,打开一个以filename(指针类型)命名的文件,返回一个指向该文件缓冲区的指针,该指针是后续操作的句柄。
2.int fclose(FILE *stream)
fclose()用来关闭先前用fopen()打开的文件。并让文件缓冲区的数据写入文件中,并释放系统提供的文件资源。成功范返回0;失败返回-1(EOF)。
示例1:
1 #include <stdio.h> 2 3 int main() 4 { 5 FILE * fp = fopen("data.txt", "w"); 6 //以"w"的方式打开一个名为"data.txt"的文件,文件不存在则创建 7 8 //判断文件是否都打开成功 9 if(fp == NULL) 10 { 11 printf("open error!\n"); 12 return -1; 13 } 14 fputs("china is great!!", fp); 15 //向文件中写入"chia is great!!" 16 fclose(fp); 17 //关闭文件 18 return 0; 19 } 20 //该程序运行完毕,在该工程目录下生成了一个"data.txt"的文本文件,其内容为上述字符串
3.int fputc(int ch,FILE *stream)
将ch字符写入文件,成功返回写入字符,失败返回-1。
int fputs(char *str,FILE *fp)
将str指向的字符串写入fp指向的文件中,正常返回0;失败返回1.
示例2:
1 #include <stdio.h> 2 int main() 3 { 4 FILE* fp = fopen("data.txt","w"); 5 if(fp == NULL) 6 { 7 printf("open error\n"); 8 return -1; 9 } 10 char ch; 11 for(ch = 'a'; ch<='z'; ch++) 12 printf("%3c",fputc(ch,fp)); 13 //将字符写入文本的同时,将其打印出来 14 fclose(fp); 15 return 0; 16 }
程序运行结果:
同时,也在工程目录下生成了一个叫"data.txt"的文件,打开文件可以发现其内容为a~z。
4.int fgetc(FILE *stream)
从文件流中读取一个字符并返回。成功返回读取的字符;读到文件末尾或失败返回-1。
char *fgets(char *str,int length,FILE *fp)
从fp指向的文件中,至多读length-1个字符,送入数组str中,如果在读入length-1个字符结束前遇到\n或EOF,读入即结束,字符串读入后在最后加一个'\0'字符。正常返回str指针,出错或遇到文件结尾,返回NULL指针。
示例3:
1 #include <stdio.h> 2 int main() 3 { 4 FILE* fp = fopen("data.txt","r"); 5 //data.txt内容为a~z 6 if(fp == NULL) 7 { 8 printf("open error\n"); 9 return -1; 10 } 11 char ch; 12 while((ch = fgetc(fp)) != EOF) 13 printf("%3c",ch); 14 fclose(fp); 15 return 0; 16 }
程序运行结果:
5.int feof(FILE *stream)
判断文件是否读到末尾,未读到末尾返回0,读到末尾返回非0。一般不用,文件读到结尾,再去读一次,容易导致多读一次。不建议使用!
6.int fread(void* buffer,int num,int count,FILE *fp)
int fwrite(void*buffer,int num,int count,FILE *fp)
将buffer指向的数据写入fp指向的文件中,或是把fp指向的文件中的数据读到buffer中,num为每个要读写的字段数的字节数,count为要读写的字段数。成功返回读/写的字段数(count);出错或文件结束返回0。这两个函数不同于其它 函数,当我们试图用fread/fwrite去读写文本文件的时候,发现文本中的格式己经没有任何意义,只是一个普通的字符。它所进行的操作为二进制操作,通俗来说就是对一些文本标识符如'\0','\n'等已经不敏感了,这些文本标识符都被当做成一个二进制来读写。
7.void rewind(FILE *STREAM)
将文件指针重新指向一个流的开头。
8.int ftell(FILE *stream)
得到流文件的当前读写位置,其返回值是当前读写位置偏离文件头部的字节数。失败返回-1。
9.int fseek(FILE *stream,long offset,int where)
偏移文件指针,成功返回0,失败返回-1。where是偏移的起始位置。
//#define SEEK_CUR 1 当前位置
//#define SEEK_END 2 文件结尾
//#define SEEK_SET 0 文件开头
fseek(fp,100L,0);把fp指针移动到离文件开头100字节处;
fseek(fp,100L,1);把fp指针移动到离文件当前位置100字节处;
fseek(fp,-100,2);把fp指针退回到离文件结尾100字节处。
示例4:
1 #include <stdio.h> 2 int main() 3 { 4 FILE* fp = fopen("data.txt","w+"); 5 if(fp == NULL) 6 { 7 printf("open error\n"); 8 return -1; 9 } 10 char ch; 11 for( ch = 'a'; ch<='z'; ch++) 12 { 13 fputc(ch,fp); 14 } 15 rewind(fp); 16 //此处一定不能少,否则文件指针将指向文件末尾,而打印不出任何东西 17 18 while((ch = fgetc(fp))&& !feof(fp)) 19 { 20 printf("%3c",ch); 21 } 22 fclose(fp); 23 return 0; 24 }
程序运行结果:
示例5:
1 #include <stdio.h> 2 int main() 3 { 4 FILE* fp = fopen("data.txt","w+"); 5 if(fp == NULL) 6 { 7 printf("open error\n"); 8 return -1; 9 } 10 fputs("abcd\nefg",fp); 11 rewind(fp); 12 char ch; 13 while((ch = fgetc(fp)) != EOF) 14 printf("%c",ch); 15 fclose(fp); 16 return 0; 17 }
程序运行结果:
示例6:下面是一个很有意思的程序,请判断下fgets()共执行了多少次;先别看答案,相信这个理解了,这部分问题就不会太大,下面直接上程序:
1 #include <stdio.h> 2 int main() 3 { 4 FILE* fp = fopen("data.txt","r"); 5 if(fp == NULL) 6 { 7 printf("open error\n"); 8 return -1; 9 } 10 char buf[10] = {0}; 11 int count = 0; 12 while(fgets(buf,10,fp) != NULL) //注意,即使没遇到结束符,每次也只能读9个字符 13 { 14 printf("%s",buf); 15 count++; 16 } 17 fclose(fp); 18 putchar(10); 19 printf("+++++++++%d++++++++++",count); 20 return 0; 21 }
其中data.txt是这样的:
程序运行结果:
从运行结果来看,似乎是执行了5次,但仔细看看,真的是5次吗?实际上,每读取一次,判断返回的指针是否为空,若不为空,则count加1,若为空,则不执行循环体。因此,实际上是读取了6次,只是最后一次读取后发现到了文件末尾,因此返回来一个空指针,判断为空指针没执行count++操作。值得注意的是fgets()每次读取的字符数。
示例7:
1 #include <stdio.h> 2 int main() 3 { 4 FILE* fp = fopen("data.txt","w+"); 5 if(fp == NULL) 6 { 7 printf("open error\n"); 8 return -1; 9 } 10 11 fputs("china is great!!",fp); 12 13 int i = ftell(fp); 14 printf("%d\n",i); 15 //打印当前指针位置离文件头的字节数 16 rewind(fp); 17 //让文件指针指向文件头 18 i = ftell(fp); 19 printf("%d\n",i); 20 21 char buf[20] = {0}; 22 fgets(buf,20,fp); 23 printf("%s\n",buf); 24 fclose(fp); 25 return 0; 26 }
程序运行结果:
示例8:
1 #include <stdio.h> 2 int main() 3 { 4 FILE* fp = fopen("data.txt","w+"); 5 if(fp == NULL) 6 { 7 printf("open error\n"); 8 return -1; 9 } 10 fputs("china is great!!",fp); 11 fseek(fp,2,0); 12 //将文件指针偏移到离文件头两个字节的位置 13 char buf[20]; 14 fgets(buf,20,fp); 15 printf("%s\n",buf); 16 fclose(fp); 17 return 0; 18 }
程序运行结果:
示例9:
1 #include <stdio.h> 2 #include <string.h> 3 int main() 4 { 5 FILE *fpw = fopen("bin.txt","wb+"); 6 if(fpw == NULL) 7 return -1; 8 char *p = "china \n is \0 great"; 9 fwrite(p,1,strlen(p)+7,fpw); 10 //将指针的内容写入到文件中,由于strlen()所求长度 11 //遇到0截止,因此需将0后面的元素补上。 12 13 rewind(fpw); 14 char buf[1024]; 15 int n = fread(buf,1,1024,fpw); 16 //每次读取一个字节,读取1024次,返回读取的字段数(此处为字节数) 17 //遇到文件末尾或读取错误返回0 18 printf("%d\n",n); 19 int i = 0; 20 for(i = 0;i<n;i++) 21 printf("%c",buf[i]); 22 fclose(fpw); 23 return 0; 24 }
程序运行结果: