【项目 - 小玩文件】 (下面是填好空的程序) (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++才能执行,这个程序的改进又可以进行了。

