我正在尝试在项目中使用std::getline()
将文本文件读入字符串数组。
这是我的代码:
ifstream ifs ( path );
string * in_file;
int count = 0;
while ( !ifs.eof() )
{
++count;
if ( count == 1 )
{
in_file = new string[1];
}
else
{
// Dynamically allocate another space in the stack
string *old_in_file = in_file;
in_file = new string[count];
// Copy over values
for ( int i = 0 ; i < ( count - 1 ) ; i++ )
{
in_file[i] = old_in_file[i];
}
delete[] old_in_file;
}
// After doing some debugging I know this is the problem what am I
// doing wrong with it?
getline(ifs,in_file[count - 1]);
}
因此,在做了一些解码后,我知道getline()没有在字符串数组中放置任何值。它似乎在数组中放置一个空字符串。
目标是阅读文本文件,如:
Hello
Bye
See you later
数组将填充如下:
in_file [0] = Hello
in_file [1] = Bye
in_file [2] = See you later
答案 0 :(得分:10)
为什么这么麻烦?
只需使用std:vector
std::string
即可
std::string str;
std::vector <std::string> vec;
while ( std::getline(ifs,str) )
{
vec.push_back(str) ;
}
如果你真的需要一个string
做:
string * in_file = new string[vec.size()];
将元素从vec
复制到in_file
for(size_t i=0;i<vec.size();i++)
in_file[i] = vec[i];
答案 1 :(得分:7)
永远不要使用以下循环从流中读取:
while ( !ifs.eof() )
在某些网站上,您会找到一个示例告诉您:
while ( ifs.good() )
这比第一个循环好一点,但它仍然非常容易出错并且不建议这样做。看看:Why is iostream::eof inside a loop condition considered wrong?
阅读文件的最常用方法是在按行阅读时使用std::getline
:
std::string line;
while ( std::getline(ifs, line) ) {
if (line.empty()) // be careful: an empty line might be read
continue;
...
}
或在阅读单词或提取具体类型(例如数字)时简单地使用>>
运算符:
std::string word;
while ( ifs >> word ) {
...
}
动态分配的std::string
对象的C风格数组:尽可能避免动态分配。相信我,你不想自己照顾内存管理。喜欢使用具有自动存储持续时间的对象。利用标准库提供的功能
正如已经指出的那样:使用诸如std::vector
之类的STL容器而不是C风格的数组:
std::ifstream ifs(path);
std::vector<std::string> lines;
std::string line;
while ( std::getline(ifs, line) )
{
// skip empty lines:
if (line.empty())
continue;
lines.push_back(line);
}