#include<iostream> using namespace std; #include<fstream> #include<stdlib.h> #include<ctype.h> struct student { char ID[6]; char name[21]; int score; }; int main() { fstream temp("people.dat",ios::in|ios::out|ios::binary); student stu; int juz=1; if(temp.fail()) { cout<<"二进制学生文件打开失败!"<<endl; exit(0); } char again; do { cout<<"首先录入学生信息!"<<endl; cout<<"请输入学生学号:"<<endl; cin.getline(stu.ID,6); cout<<"请输入学生姓名:"<<endl; cin.getline(stu.name,21); cout<<"请输入学生分数:"<<endl; cin>>stu.score; cin.ignore(); temp.write((char*)&stu,sizeof(stu)); cout<<"是否要录入下一个学生信息,如果是请输入y(不区分大小写)!"<<endl; cin>>again; cin.ignore(); }while(again=='y'&&again=='Y'); temp.close(); temp.open("people.dat",ios::in|ios::out|ios::binary); if(temp.fail()) { cout<<"二进制学生文件打开失败(读取)!"<<endl; exit(0); } do { temp.read((char*)&stu,sizeof(stu)); if(juz==3) { cout<<"学生姓名:"<<stu.name<<endl; cout<<"学生学号:"<<stu.ID<<endl; cout<<"学生成绩:"<<stu.score<<endl; } juz++; }while(!temp.eof()); cout<<"操作完毕!"<<endl; temp.close(); getchar(); getchar(); return 0; } 找出这段代码的问题
时间: 2023-10-30 15:44:58 浏览: 111
#include_iostream.h_
4星 · 用户满意度95%
这段代码存在以下问题:
1. 在使用fstream打开文件时,应该检查文件是否成功打开。可以使用`if(!temp)`来检查文件是否打开失败,然后显示错误信息并退出程序。
2. 在读取学生信息之前,应该先判断文件是否为空。可以使用`temp.tellg()`来获取当前文件位置,如果位置为0,则说明文件为空。
3. 在录入学生信息时,应该使用`cin.ignore()`来清除输入缓冲区中的换行符。
4. 在录入下一个学生信息之前,应该先清除输入缓冲区中的换行符。可以使用`cin.ignore()`。
5. 在判断是否要录入下一个学生信息时,应该使用逻辑运算符`||`而不是`&&`。即应该是`while(again=='y'||again=='Y')`。
6. 在读取学生信息之后,应该检查读取操作是否成功。可以使用`temp.fail()`来检查读取操作是否失败,然后显示错误信息并退出程序。
7. 在读取学生信息时,应该在循环开始前将juz重置为1,以确保只输出第三个学生的信息。
8. 在输出学生信息之后,应该将juz加1,以便判断下一个学生是否为第三个。
9. 在循环读取学生信息时,应该使用`temp.eof()`来判断文件是否已经读取到末尾。即循环条件应该是`while(!temp.eof())`。
10. 在文件操作完毕后,应该关闭文件。
以上是我发现的一些问题,希望对你有帮助!
阅读全文