为什么数据没有正确写入/读取此文件?

时间:2019-04-20 13:23:52

标签: c++

以下代码仅从对象中的用户那里接收一些数据并将其写入二进制文件中。第一个对象写的很好,但是之后就弄乱了。

下面是将第一个对象写入文件后读取文件的输出。

ROLL NO.      NAME          MARKS
234            Sansa           67

一切正常,正如我期望的那样。但是,当我在文件中附加另一个对象时,就会发生这种情况。

ROLL NO.      NAME          MARKS
234         SansSnow           78
564         Jon Snow           78

卷号保持不变,但是先前对象的名称与最后一个对象的名称混合在一起,并且它们的标记被最后一个对象的标记覆盖。 为什么会发生?

代码:

#include <iostream>
#include <fstream>
#include <iomanip>

using namespace std;

fstream file;

class Student
{
protected:
    int rollno;
    char name[30];
    float marks;
public:
    void getData()
    {
        cout<<"ENTER THE DATA..."<<endl<<endl;
        cout<<"Roll Number : ";
        cin>>rollno;
        fflush(stdin);
        cout<<"Name : ";
        cin.getline(name,30);
        cout<<"Marks : ";
        cin>>marks;
    }
    void displayData()
    {
        cout<<"\n"<<rollno;
        cout<<setw(17)<<name;
        cout<<setw(13)<<marks;
    }
    void writeData()
    {
        file.open("StudentData.dat", ios::app|ios::binary);
        file.write((char*)this, sizeof(this));
        file.close();
    }
    void readData()
    {
        file.open("StudentData.dat",ios::in|ios::binary);
        while(file.read((char*)this, sizeof(this)))
        {
            displayData();
        }
        file.close();
    }
};

Student S1;

int main()
{
    cout<<"\nMAIN MENU"<<endl<<endl;
    cout<<"1. Enter data and write to file\n";
    cout<<"2. Read data from file and display\n";
    cout<<"3. Exit\n\n";
    cout<<"Enter your choice : ";
    int choice;
    cin>>choice;

    switch(choice)
    {
        case 1:{
            S1.getData();
            S1.writeData();
            cout<<endl<<endl;
            cout<<"Data written to file successfully!"<<endl;
            main();
            break;
        }
        case 2:{
            cout<<"ROLL NO."<<setw(10)<<"NAME"<<setw(15)<<"MARKS";
            S1.readData();
            cout<<endl;
            main();
            break;
        }
        case 3:{
            exitop:
            char confirmExit;
            cout<<"\nAre you sure you want to exit? (Y/N) : ";
            cin>>confirmExit;
            if(confirmExit=='y' or confirmExit=='Y')
                exit(0);
            else if(confirmExit=='n' or confirmExit=='N')
            {
                cout<<"Exit Aborted.\n\n";
                getchar();
                main();
            }
            else{
                cout<<"Invalid Input!";
                goto exitop;

            }
        }
        default:{
            cout<<"Invalid Input!";
            break;
        }
    }
    return 0;
}

1 个答案:

答案 0 :(得分:2)

您只读写8个字节。 this是一个指针,因此sizeof(this)为8(在64位计算机上)。您实际要做的是获取对象的大小,因此使用sizeof(*this)sizeof(Student)