使用feof()函数判断文件是否结束

课本上时这样写的:(用putchar(ch);代表对取出来的字符的处理。)

1 while(!feof(fp))
2 {
3     ch=fgetc(fp);
4     putchar(ch);
5 }

但是,这样写的话,fgetc()函数总是会多读入一个字符。

应该改为如下形式:

1 ch=fgetc(fp);
2 while(!feof(fp))
3 {
4     putchar(ch);
5     ch=fgetc(fp);
6 }

只有当从文件输入“文件结束符”后,才能使用feof(fp)函数判断文件是否结束。

课本上的代码是这样运行的:使用ch=fgetc(fp);从文件读入了文件结束符,然后输出文件结束符(-1)对应的字符(其实是乱码,没有ASCII为-1的字符),然后再根据!feof(fp)为假,判断文件结束,其实文件在前一次循环中已经结束了。

代码还可以这样写:

1 ch=fgetc(fp);
2 while(ch!=EOF)
3 {
4     putchar(ch);
5     ch=fgetc(fp);
6 }

处理文本文件,在判断文件是否结束时,两种方法:ch!=EOF;或者!feof(fp);除了这两个表达式之外的其它代码不要变动。

处理二进制文件,只能使用!feof(fp)判断文件是否结束。

原文地址:https://www.cnblogs.com/Camilo/p/3379538.html