我想知道,如果有另一种方法来读出一个大文件
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多个fouts?
还有其他办法吗?
答案 0 :(得分:10)
您可以定义一个类来保存每个人的数据:
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)
。因此,向量将有足够的内存来存储所有记录而无需重新分配,如果文件很大,这可能会加速加载。
答案 1 :(得分:1)
如果您使用的是Linux,则可以mmap()大文件,并使用内存中的数据。