10

我试图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
4

2 回答 2

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()];

并将元素从复制vecin_file

for(size_t i=0;i<vec.size();i++)
 in_file[i] = vec[i];
于 2013-10-01T18:33:35.280 回答
10

永远不要使用以下循环包装从流中读取的内容:

while ( !ifs.eof() )

在某些网站上,您会找到一个示例,告诉您这样做:

while ( ifs.good() )

这比第一个循环好一点,但仍然很容易出错,不建议这样做。看看:为什么循环条件内的 iostream::eof 被认为是错误的?

读取文件的最常见方法是在逐行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 ) {               
    ...
}

对于您动态分配的 C 风格的std::string对象数组:尽可能避免动态分配。相信我,你不想自己处理内存管理。更喜欢使用具有自动存储持续时间的对象。利用标准库提供的功能。
正如已经指出的那样:使用 STL 容器std::vector代替 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);
}
于 2013-10-01T18:50:01.190 回答