到达文件结尾有两种可能的解释:
一是当程序从一个文件读取数据时,在程序读取文件中的最后一项之后就立即出现文件结束的条件。另一种是只有当程序想越过文件的最后一项进行读取时才出现文件结束的条件。
Ada和Pascal采用第一种解释。在这些语言中,一个从外部文件读取数据的DO循环应该形如(用C++语言来写):
do{
if (infile.eof()) break;
double amount;
infile>>amount;
......}
C++,JAVA采用第二种解释,在这些语言中,一个从外部文件读取数据的DO循环应该形如(用C++语言来写):
do{
double amount;
infile>>amount;
if(infile.eof()) break;
......}
如果在一个c++程序中使用了第一种循环结构,会发生什么情况呢?最后一个值将从文件中读取并由循环的余部分处理,在下一次循环中eof()将返回false,于是语句infile>>amount;将又执行一次。当没有数据时,将出现文件结束的条件,但内存中amount的值仍然是一样的(在大多数系统中)。由于程序不知道已经没有数据,循环的余下部分将继续处理最后一个值,好像它在输入文件中出现了两次一样。在下一次循环中,将出现文件结束的条件,于是循环终止。
(在C++中,文件的结束符在程序从文件中读取最后一项时并没有出现。它是在下一次读取时,即当程序想越过最后一个文件项读取时才出现)
也可以用infile.fail()来检查。