我想知道,是否还有另一种读取大文件的方法
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)
。因此,向量将有足够的内存来存储所有记录而无需重新分配,如果文件很大,则可能潜在地加快加载速度。