我试图通过以下代码读取文件
void main()
{
int i=0;
ifstream fout1 ("Aj.txt",ios::binary);
if (fout1.is_open())
{
while(fout1)
{
i++;
fout1.get(ch1);
cout<<ch1;
}
cout<<i;
fout1.close();
}
else
{
cout << "Unable to open file";
}
return 0;
}
这里,这段代码读取整个文件,但它会进入一次额外的循环,即如果文件中有4个字符,那么在循环中它会迭代5次。如何纠正或克服它
该代码读取直到设置了eof
标志,但直到读取实际失败才设置eof
标志。这意味着当fout1.get(ch1)
读取最后一个字符时,eof
是而不是设置。所以它显示,并检查fout
,它仍然是好的,所以它重新进入循环。然后fout1.get(ch1)
因为eof失败,它又显示了之前的ch1
的值。写这个循环的正确方法是:
while(fout1.get(ch1)) { //false when it can't read any more characters
i++;
cout<<ch1;
}
cout<<i;
fout1.close();
读取第4个字符后,流仍然处于良好状态,因此它尝试读取第5个字符,此时它遇到文件结束。您应该在调用get
之后检查流状态。例如:
while( fout1.get(ch1) )
{
cout << ch1;
++i;
}
如果您不熟悉iostreams,这是一个容易犯的错误。如果您只读取文件中的最后一个字符,stream.eof()
将为false。只有当尝试读取文件末尾的之后的时,才会出现这种情况。你需要一个像这样的内循环:
for (;;)
{
fout1.get(ch1);
if (!fout1) break;
cout << ch1;
i++;
}