我想知道,是否还有另一种读取大文件的方法

Hans //name

Bachelor // study_path

WS10_11 //semester

22 // age


而不是这样:

fout >> name; //string

fout >> study_path; //string

fout >> Semester ; //string

fout >> age; //int


当我的文件超过20行时,我应该进行20次以上检测?

还有另一种方法吗?

最佳答案

您可以定义一个类来保存每个人的数据:

class Person {
public:
    std::string name;
    std::string study_path;
    std::string semester;
    unsigned int age;
};


然后,您可以为该类定义流提取运算符:

std::istream & operator>>(std::istream & stream, Person & person) {
    stream >> person.name >> person.study_path >> person.semester >> person.age;
    return stream;
}


然后,您可以像这样读取整个文件:

std::ifstream file("datafile.txt");
std::vector<Person> data;
std::copy(std::istream_iterator<Person>(file), std::istream_iterator<Person>(),
          std::back_inserter(data));


这将读取整个文件,并将所有提取的记录存储在vector中。如果您知道将预先读取的记录数,则可以在读取文件之前调用data.reserve(number_of_records)。因此,向量将有足够的内存来存储所有记录而无需重新分配,如果文件很大,则可能潜在地加快加载速度。

10-07 19:17
查看更多