在测试我的代码时,我遇到了一个问题,即当将更多数据写入其文件时,ifstream
不会更新。所以这是一个演示问题的示例代码:
ifstream is(filename);
string line;
while (getline(is, line))
cout << "line: " << line << endl;
ofstream os(filename, ofstream::out | ofstream::app);
string additional("additional");
os << additional;
os.flush();
while (getline(is, line))
cout << "line additional: " << line << endl;
没有额外的行写入stdout
,尽管它们被写入文件。
我没有使用fstream
而不是几个if / ofstream,因为出于测试目的我需要这样做。
如何让ifstream
“看到”文件中的更改?
UPDATE :我使用clear
方法清除了这些位。它在我的Ubuntu机器上使用gcc正常工作。但它在llvm的Mac OSX上不起作用。你知道如何独立完成平台吗?
答案 0 :(得分:3)
首次阅读后,您需要在输入流上调用std::ios::clear
。
当您读取整个文件时,它会在流中设置failbit并拒绝继续读取,即使文件在此期间实际发生了更改。
ifstream is(filename);
string line;
while (getline(is, line))
cout << "line: " << line << endl;
ofstream os(filename, ofstream::out | ofstream::app);
string additional("additional");
os << additional;
os.flush();
is.clear(); //< Now we can read again
while (getline(is, line))
cout << "line additional: " << line << endl;
答案 1 :(得分:2)
当您第一次阅读is
时点击文件末尾时,它会在流的内部错误状态中设置eofbit
。
在继续阅读之前,您需要先清除它,方法是调用is.clear()
功能,该功能会重置内部错误状态。
答案 2 :(得分:0)
我认为原因是您使用&#34; ofstream :: out&#34;
打开了输出流文件ofstream os(filename, ofstream::out | ofstream::app);
现在,&#34; ofstream :: out&#34;打开文件后立即截断文件。也就是说,文件的所有先前内容一旦打开就会被删除。请尝试使用此代码:
ofstream os(filename, ios::app);