【项目 - 小玩文件】
(下面是填好空的程序)
(1)下面程序的功能是统计文本文件abc.txt中的字符个数,请填空将程序补充完整。

#include <iostream>
#include <cstdlib>
#include <fstream> // (1)
using namespace std;
int main()
{
    fstream file;
    file.open("abc.txt", ios::in); // (2)
if(!file)
{
        cout<<"abc.txt can’t open."<<endl;
        exit(1);
    }
    char ch;
    int i=0;
    while(file.get(ch)) // (3)
    {
        ++i; // (4)
    }
    cout<<"Character: "<<i<<endl;
    file.close();// (5)
    return 0;
}

(2)下面程序的功能是将文本文件abc.txt中的所有行加上行号后写到newabc.txt文件中,请填空将程序补充完整。

#include <iostream>
#include <cstdlib>
#include <fstream>
using namespace std;
int main()
{
    fstream outfile,infile;
    infile.open("abc.txt",ios::in); // (1)
    if(!infile)
    {
        cout<<"Can’t open the file."<<endl;
        abort();
    }
    outfile.open("newabc.txt",ios::out);//(2)
    if(!outfile)
    {
        cout<<"Can’t open the file."<<endl;
        abort();
    }
    char buf[80];
    int i=1;
    while(!infile.eof()) // (3)
    {
        infile.getline(buf, 80); // (4)
        outfile<<i++<<": "<<buf<<endl; //(5)
    }
    infile.close();
    outfile.close();
    return 0;
}

PS:当abc.txt文件中存在长于80个字符的行时,程序会陷入死循环。通过跟踪发现,从当遇到这个“超长”的行时,infile.getline(buf, 80)先读出79个字符,以\0结束,之后再读,buf[0]总是\0,同时!infile.eof()为假,所以进入死循环。怀疑这其中该是这种“截断”式读取超长行带来的副作用。参看《getline的获取ifstream的数据》,其中给出了解释与对策。
显然,当初的这个程序并未考虑超长行,而是默认每一行都不会达80个字符而设计的。注意:如果某一行就这样被“截断”了,并不意味着这就是一行,直到找到换行符,才能说明这是一行的结束,行数i++才能执行,这个程序的改进又可以进行了。