我应该使用什么条件来停止文件读取循环
What condition should I use to stop a file reading loop?
以下会导致错误,因为file.eof()
显然不会返回true
,直到读取超过文件末尾。我应该怎么做?
std::ifstream file("something.stuff", std::ios::in|std::ios::binary);
while(!file.eof())
{
double x, y, z;
file.read(reinterpret_cast<char*>(&x), sizeof(x)); // Do I need to check if(file) after every read?
file.read(reinterpret_cast<char*>(&y), sizeof(y));
file.read(reinterpret_cast<char*>(&z), sizeof(z));
// Do something with xyz
}
您可以在所有读取后检查它,除非您打算对部分数据执行某些操作,因此:
while(true)
{
double x, y, z;
file.read(reinterpret_cast<char*>(&x), sizeof(x));
file.read(reinterpret_cast<char*>(&y), sizeof(y));
file.read(reinterpret_cast<char*>(&z), sizeof(z));
if (!file)
break;
// Do something with xyz
}
std::ifstream::read
应该在阅读文件末尾后设置eof
标志。
所以,是的,你应该在每次打电话给file.eof()
后检查file.read()
。
或者,使用查找和告诉预先查找文件的长度,然后计算应执行的迭代次数。这样,您就不必在每次读取后继续检查 eof 位。
是的,每次读取期间都可以到达流的末尾,因此您应该在继续之前检查每个流是否成功
std::ifstream file("something.stuff", std::ios::in|std::ios::binary);
while(!file.eof())
{
double x, y, z;
if (!file.read(reinterpret_cast<char*>(&x), sizeof(x)) ||
!file.read(reinterpret_cast<char*>(&y), sizeof(y)) ||
!file.read(reinterpret_cast<char*>(&z), sizeof(z)))
{
// failure... perhaps check file.eof() and/or file.fail() for precise condition
break;
}
else
{
// Do something with xyz
}
}
相关文章:
- 正在将csv文件读取为双精度矢量
- 将从格式化文本文件读取的文本数据存储到链表
- C++ 读取文件读取文件不正确
- 使用对象文件读取三角形数据网格
- 如何减慢从 BVH 文件读取的 opengl 动画?
- 从文件读取,并写入函数C++中的数组
- 从对象C++中的文件读取内容时出现分段错误
- 从文件读取并通过矢量输出到控制台
- 尝试将字符串从文件读取到无符号字符向量中
- 如何将文本文件读取到二维数组中并以 c++ 打印
- 简化文件读取的函数
- 如何将逗号分隔的文件读取为 2D int 数组?
- 在 c++ 中将数据从文件读取到队列中
- 'std::wstring_convert'尽可能多地转换(从 UTF8 文件读取块)
- C++,从文件读取到结构,然后读取到向量(结构被推入向量太多次,而不仅仅是一次)
- 文件读取C++包括空格键
- 从文件读取时未将值推回矢量
- 从文件 C++ 读取时的无限循环
- 从同一文件读取和写入?
- 从.txt文件读取到C++中的双精度向量