读取文件时获取两次相同的输出

时间:2015-01-28 04:45:07

标签: c++ class fstream

我遇到以下程序的问题,

#include<iostream>
#include<fstream>
#include<windows.h>

using namespace std;

class student
{
    int rollno;
    char name[50];
    int cls;
    int marks;
    char grade;
public:
    void getdata()
    {
        cout<<"Enter Roll No.: ";
        cin>>rollno;
        cout<<"Enter Name: ";
        cin>>name;
        cout<<"Enter Class: ";
        cin>>cls;
        cout<<"Enter Marks: ";
        cin>>marks;
        if(marks>=75)
        {
            grade='A';
        }
        if(marks>=60 && marks<75)
        {
            grade='B';
        }
        if(marks>=45 && marks<60)
        {
            grade='C';
        }
        if(marks>=35 && marks<45)
        {
            grade='D';
        }
        if(marks<35)
        {
            grade='F';
        }
    }

    void display()
    {
        cout<<"\nRoll No.: "<<rollno;
        cout<<"\nName: "<<name;
        cout<<"\nClass: "<<cls;
        cout<<"\nMarks: "<<marks;
        cout<<"\nGrade: "<<grade<<endl;
    }

    int rno()
    {
        return rollno;
    }
} s1, s2, s3;

void append()
{
    fstream fo ("STUDENT.DAT",ios::binary | ios::app | ios::out);
    if(!fo)
    {
        cout<<"CANNOT OPEN FILE!!!!!";
    }

    else
    {
        s1.getdata();
        fo.write((char*)&s1, sizeof(s1));
    }
    fo.close();

}

void sdisplay()
{
    fstream fi ("STUDENT.DAT",ios::binary | ios::in);
    if(!fi)
    {
        cout<<"\nNO RECORDS !!!!";

    }
    else
    {

        while(!fi.eof())
        {
            fi.read((char*)&s2, sizeof(s2));
            if(s2.rno()!='\0')
            {
                s2.display();
            }
        }
    }
    fi.close();
}

void rdisplay()
{
    int n, found;
    fstream fi ("STUDENT.DAT", ios::in | ios::binary);
    if(!fi)
    {
        cout<<"\nNO RECORDS !!!!";
    }

    else
    {
        cout<<"\nEnter Roll No. to be displayed: ";
        cin>>n;
        while(!fi.eof())
        {
            fi.read((char*)&s3, sizeof(s3));
            if(s3.rno()==n)
            {
                s3.display();
                found=1;
            }
        }
        if(found!=1)
        {
            cout<<"\nCannot find roll no!!";
        }
    }
    fi.close();
}

int main()
{
    char ch='y';
    int choice, n;

    while(ch=='y' || ch=='Y')
    {
        cout<<"\n1. Append Data to File";
        cout<<"\n2. Display Entire File";
        cout<<"\n3. Search & Display record based on Roll No.";
        cout<<"\n4. Exit";
        cout<<"\n\n Enter your choice (1-4): ";
        cin>>choice;
        switch(choice)
        {
        case 1:
            append();
            break;

        case 2:
            sdisplay();
            break;

        case 3:
            rdisplay();
            break;
        case 4:
            exit(0);
            break;

        default:
            cout<<"\nWrong Choice !!!!!";
            break;
        }
        cout<<"\n\nDo you want to continue? (Y/N)";
        cin>>ch;
    }
}

因此,在附加数据后,当我转到显示数据(选项2和3)时,它会输出相同的条目两次。

  
      
  1. 将数据附加到文件
  2.   
  3. 显示整个文件
  4.   
  5. 搜索&amp;显示基于卷号
  6. 的记录   
  7. 退出

         

    输入您的选择(1-4):2

  8.         

    没有记录!!!!

         

    你想继续吗? (Y / N)Y

         
        
    1. 将数据附加到文件
    2.   
    3. 显示整个文件
    4.   
    5. 搜索&amp;显示基于卷号
    6. 的记录   
    7. 退出

           

      输入您的选择(1-4):1输入卷号:23输入名称:James Enter   等级:12输入标记:85

    8.         

      你想继续吗? (Y / N)Y

           
          
      1. 将数据附加到文件
      2.   
      3. 显示整个文件
      4.   
      5. 搜索&amp;显示基于卷号
      6. 的记录   
      7. 退出

             

        输入您的选择(1-4):2

      8.         

        卷号:23名称:詹姆斯等级:12分:85等级:A

             

        卷号:23名称:詹姆斯等级:12分:85等级:A

             

        你想继续吗? (Y / N)N

             

        进程返回0(0x0)执行时间:25.013秒按任意键   继续。

有人能帮助我吗? 感谢

1 个答案:

答案 0 :(得分:2)

eof()在你读完之前不会被设定,直到你的第二次阅读才会发生。该读取将无效,因此它不会覆盖s2,它只会失败 - 所以您最终会再次打印该行。

解决方案不要在eof()上循环。只需循环read()

while(fi.read((char*)&s2, sizeof(s2)))
{
    s2.display();
}