int
feof(FILE
*fp)
功能为判断文档是否结束,如果已经达到文件尾,返回1,否则返回0.
除此外,部分读函数本身返回值同样可以判断是否结尾。
1
fgets,
返回NULL表示文件结尾。
2
fscanf,
fgets等,返回EOF表示=文件结尾。
其实二进制方式和文本方式判断文件结束的方式是一样的,都是遇到EOF就认为文件结束,EOF是一个宏,它代表了-1这个值,如果在文件当中读到了0xff或者到了文件末尾,文件结构指针里面的flags字节的_F_EOF位都会被置为1,这一位被置为1,库函数就会认为到了文件末尾了。函数feof()其实是一个类函数宏,这个宏就是通过把文件结构指针的flags字节跟_F_EOF进行与运算来检测_F_EOF是否为1,并判断是否到了文件末尾的。这个函数具有与下面类似的代码:#define feof(f) ((f)->flags & _F_EOF)
对于flags和_F_EOF,不同的编译器可能有不同的标识符。
feof是返回值为0表示遇到文件末尾的。上述那个_F_EOF应该是被置为0表示文件末尾,而feof是通过检测flags跟_F_EOF相与的结果是否为0来判断文件是否到了末尾。
另外提醒一下。刚刚查阅了一些更详细的资料,发现我所说的那种把-1当作文件结束标记的情况并非发生在所有的 *** 作系统上。某些 *** 作系统特别是早期的 *** 作系统有不少就把-1看作文件结束标记,但现在的 *** 作系统多数来说不再以这种方法判断文件结束,而是直接比较文件的大小,DOS、windows和一部分unix/linux就是以文件大小来判断的,当超过文件大小读的时候,就会设置_F_EOF和_O_EOF位。
如果文件末尾有一个空行,注意特别注意用fgets进行读,比如文件:aaa 234 444 bbb
123 kkk 9 00 00000 0000
ccc 34
如果最后没有空行,即没有\n,读到ccc 34这行时,fgets遇到了EOF,结束,str="ccc 34\0"如果最后有空行;读到ccc 34这行时,fgets遇到了new line,str="ccc 34\n\0",此时文件未返回EOF,再次fgets时,遇到EOF,fgets返回NULL,str的内容没有变,因此用fgets读时判断是否该结束最好如此:
while(fgets(...)) {
...
}
而不要用
while(!feof()) {
fgets()
...
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)