课本上时这样写的:(用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)判断文件是否结束。