讀取文件時,使用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);
    }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM