读取文件时,使用file.eof()判断结尾注意事项

今天写一个小功能需要读取文件,在判断文件结尾时使用了以下语句:

1     while(infile.eof() && infile.good())
2     {
3         infile.read((char*)&data, 1);
4         encodeData = data ^ CODE;
5         outfile.write((char*)&encodeData, 1);
6     }

结果最后一个字符会读取两次,后来换了种方式,事先读取文件长度,再循环,就能争取读取文件:

    for(int i=3; i<file_len; ++i)
    {
        infile.read((char*)&data, 1);
        encodeData = data ^ CODE;
        outfile.write((char*)&encodeData, 1);
    }

最后了解到,是因为read函数需要读取失败时才将eofbit置位,所以置位时,循环还会执行一次。修改代码就没有问题了:

    while(infile.read((char*)&data, 1) && !infile.eof() && infile.good())
    {
        encodeData = data ^ CODE;
        outfile.write((char*)&encodeData, 1);
    }
原文地址:https://www.cnblogs.com/zhanghang-BadCoder/p/7057887.html