这是一个用于解析文本文件的示例,如果我在内部while循环之外声明“string parm”,则问题是一行的最后一个字符串总是得到双重输出(这只发生在一些空格字符出现在“source.txt”中每一行的结尾,如果不是一切正常的话)。我可以通过删除“source.txt”中的附加空格字符或通过在内部while循环中声明“string parm”来修复此问题,但我仍然无法弄清楚导致双输出的原因,是什么想法?
#include <iostream>
#include <string>
#include <fstream>
#include <sstream>
using namespace std;
void main(int argc, char* argv[])
{
string f_string = "source.txt";
ifstream inputFile(f_string, ifstream::in);
char line[1024];
while(inputFile.getline(line, 1023))
{
stringstream ss(stringstream::in | stringstream::out);
ss.str(line);
string parm; // final string will preserved ???
while(!ss.eof())
{
//string parm; final string won't get double output if declare here ...
ss >> parm;
cout << parm << endl;
if(parm.compare("value") == 0)
cout << "Got value." << endl;
}
cout << endl;
}
}
使用source.txt,如下所示:
1st name_1 value
2nd name_2 value
3rd name_3
如果每行末尾出现一些空格字符,我就明白了:
1st
name_1
value
Got value.
value
Got value.
2nd
name_2
value
Got value.
value
Got value.
3rd
name_3
name_3
如果没有,或者在内部while循环中声明“string parm”,我得到了更合理的结果:
1st
name_1
value
Got value.
2nd
name_2
value
Got value.
3rd
name_3
答案 0 :(得分:1)
将代码更改为:
while(ss >> parm)
{
cout << parm << endl;
if(parm.compare("value") == 0)
cout << "Got value." << endl;
}
我怀疑的问题是while(!ss.eof())
。有关详细说明,请参阅Why is iostream::eof inside a loop condition considered wrong?。
//string parm; final string won't get double output if declare here
如果在循环中声明string parm
,则每次循环时都会得到一个空字符串。当ss >> parm
失败时,不会将任何内容读入字符串并输出空字符串。