2

以下导致错误,因为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
}
4

4 回答 4

9

您可以在所有读取后检查它,除非您打算对部分数据执行某些操作,因此:

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
}
于 2012-07-01T18:37:19.143 回答
1

std::ifstream::readeof一旦你读到文件末尾,就应该设置标志。

所以,是的,你应该file.eof()在每次调用file.read().

于 2012-07-01T18:34:00.427 回答
1

或者,使用 seek 和 tell 预先找到文件的长度,然后计算应该执行多少次迭代。这样您就不必在每次读取后继续检查 eof 位。

于 2012-07-01T18:35:33.923 回答
1

是的,每次读取都可能到达流的末尾,因此您应该在继续之前检查每个读取是否成功

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 
    }
}
于 2012-07-01T18:39:11.977 回答