使用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)判断文件是否结束。

你可能感兴趣的:(文件)