如何使用std :: getline()将文本文件读入C ++中的字符串数组?

时间:2013-10-01 18:29:45

标签: c++ arrays file-io fstream dynamic-arrays

我正在尝试在项目中使用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

2 个答案:

答案 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);
}