-1

如何使用默认的类构造函数创建多个新的类对象?

对于一个项目,我必须编写一个将三个类对象写入文件的程序。我已经完成了……下一部分是能够使用 readData 函数将数据读回三个单独的类对象,然后显示数据。我完全不知道如何做到这一点,所以我在 readData 函数中没有任何代码。

以下是对象在写入文件时的外观示例。

employee name(21, "first last", "45 East State", "661-9000", 30, 12.00);

这是我的大部分代码,员工类是相当基本的,但这是默认的类构造函数。

employee::employee ();
employee::employee(int locEmpNumber, string locName, string locaddress, string locphone, double locHrWorked, double locHrWage)



#include "employee.h" 
#include <string>
#include <iomanip>
#include <iostream>
#include <fstream>
using namespace std;

void writeData (const employee& e);
void readData (const employee& e);
void printCheck (const employee& e);


int main( )
{
//Declarations
const int ONE = 1;
const int TWO = 2;

int userInput;

cout << "This program has two options:" << endl;
cout << "1 - Create a data files called 'EmployeeInfo.txt', or" << endl;
cout << "2 - Read data from a file and print paychecks." << endl;
cout << "Please enter (1) to create a file or (2) to print checks: ";

cin >> userInput;

if (userInput == ONE)
{
    //Create employee objects:
    employee joe(37, "Joe Brown", "123 Main St.", "123-6788", 45, 10.00);
    employee sam(21, "Sam Jones", "45 East State", "661-9000", 30, 12.00);
    employee mary(15, "Mary Smith", "12 High Street", "401-8900", 40, 15.00);

    ofstream empFile ("EmployeeInfo.txt");

    //Employee objects to write themselves out to the file.
    writeData(joe);
    writeData(sam);
    writeData(mary);

    //Close the file.
    empFile.close();

    //Print an message that creation of the file is complete.
    system("CLS");
    cout << "\nCreation of 'EmployeeInfo.txt' has completed.\n";
    cout << "\nYou can now run option 2.\n";

    //Exit.
    system("PAUSE");
    return 0;
}
else if (userInput == TWO)
{
    //Create three new Employee objects, using the default Employee constructor.

    //Open the file that you just saved.

    //Have each object read itself in from the file.

    //Call the printCheck( ) function for each of the three new objects, just as you did in the previous project.
}
else
{
    system("CLS");      
    cout << "Incorrect entry.... Please try again and follow directions closely! \n" << endl;
    system("PAUSE");
    return 0;
}


}

void writeData(const employee& e)
{
fstream empFile;
empFile.open ("EmployeeInfo.txt", ios::app);

empFile << e.getEmpNumber() << "\n";
empFile << e.getName() << "\n";
empFile << e.getAddress() << "\n";
empFile << e.getPhone() << "\n";
empFile << e.getHrWorked() << "\n";
empFile << e.getHrWage() << "\n";
}

void readData(const employee& e)
{
fstream empFile;    
empFile.open ("EmployeeInfo.txt", ios::in);

if(empFile.fail())
{
    cout << "File could not be open. Please try option 1 then option 2.\n" << endl; 
    return;
}

}
4

1 回答 1

0

很高兴看到您为解决问题做出了努力。但是,您在问题中提出的内容与代码中的某些注释不匹配。在我看来,您的简报的一个关键部分似乎很清楚,员工对象本身需要能够将自己写入文件并从文件中读取自己。

您已经编写了将对象的内容写入文件而不是让对象将自身写入文件的代码。看起来我在这个问题上分心,但这是面向对象编程的精髓所在。将功能封装在对象本身中是这里的真正目标。

我在下面包含了一些代码来帮助你。希望这对您有意义。

class employee
{
private:
    int _locEmpNumber;
    std::string _locName;
    std::string _locAddress;
    std::string _locPhone;
    double _locHrWorked;
    double _locHrWage;

public:
    employee();
    employee(int locEmpNumber, std::string locName, std::string locAddress, std::string locPhone, double locHrWorked, double locHrWage);

    //object should be able to save itself as per your project brief.
    void writeData(std::ofstream &empFile);

    //object should be able to read itself from file as per your project brief
    void readData(std::ifstream &empFile);
};

employee::employee()
{
    _locEmpNumber = 0;
    _locHrWorked = _locHrWage = 0;
}


employee::employee(int locEmpNumber, std::string locName, std::string locAddress, std::string locPhone, double locHrWorked, double locHrWage)
{
    _locEmpNumber = locEmpNumber;
    _locName = locName;
    _locAddress = locAddress;
    _locPhone = locPhone;
    _locHrWorked = locHrWorked;
    _locHrWage = locHrWage;
}

//
//From what I can glean from your brief ...
//Employee objects to write themselves out to the file!!!
void employee::writeData(std::ofstream &empFile)
{
    empFile << _locEmpNumber << std::endl;
    empFile << _locName << std::endl;
    empFile << _locAddress<< std::endl;
    empFile << _locPhone << std::endl;
    empFile << _locHrWorked << std::endl;
    empFile << _locHrWage << std::endl;
}

//
//Again, from what I can glean from your brief ...
//Have each object read itself in from the file!!!
void employee::readData(std::ifstream &empFile)
{
    //Normally you would have error handling in a method like this and
    //would either return a response that indicates that the operation
    //succeded or failed. You might alternatively use exception handling
    //or indeed a combination of both.
    //
    //Normally you would reset all members to initial / empty values before
    //reading values into them from your file. In this case we will omit that
    //for the purposes of simplicity. The main reason you would reset members
    //is to ensure that when reusing an object you don't end up with partial
    //data from the current "read" operation mixed with partial data that
    //was already in the object before you started reading.
    std::string inputStr;
    std::getline(empFile, inputStr);
    _locEmpNumber = atoi(inputStr.c_str());
    std::getline(empFile, _locName);
    std::getline(empFile, _locAddress);
    std::getline(empFile, _locPhone);
    std::getline(empFile, inputStr);
    _locHrWorked = atof(inputStr.c_str());
    std::getline(empFile, inputStr);
    _locHrWage = atof(inputStr.c_str());
}


int main(int argc, char* argv[])
{
    //Declarations
    const int ONE = 1;
    const int TWO = 2;

    int userInput;

    std::cout << "This program has two options:" << std::endl;
    std::cout << "1 - Create a data files called 'EmployeeInfo.txt', or" << std::endl;
    std::cout << "2 - Read data from a file and print paychecks." << std::endl;
    std::cout << "Please enter (1) to create a file or (2) to print checks: ";

    std::cin >> userInput;

    if (userInput == ONE)
    {
        //Create employee objects:
        employee joe(37, "Joe Brown", "123 Main St.", "123-6788", 45, 10.00);
        employee sam(21, "Sam Jones", "45 East State", "661-9000", 30, 12.00);
        employee mary(15, "Mary Smith", "12 High Street", "401-8900", 40, 15.00);

        std::ofstream empFile ("EmployeeInfo.txt");

        //Employee objects to write themselves out to the file.
        joe.writeData(empFile);
        sam.writeData(empFile);
        mary.writeData(empFile);
//      writeData(joe);
//      writeData(sam);
//      writeData(mary);

        //Close the file.
        empFile.close();

        //Print an message that creation of the file is complete.
        system("CLS");
        std::cout << "\nCreation of 'EmployeeInfo.txt' has completed.\n";
        std::cout << "\nYou can now run option 2.\n";

        //Exit.
        system("PAUSE");
        return 0;
    }
    else if (userInput == TWO)
    {
        //Create three new Employee objects, using the default Employee constructor.
        employee joe;
        employee sam;
        employee mary;

        //Open the file that you just saved.
        std::ifstream empFile("EmployeeInfo.txt");

        //Have each object read itself in from the file.
        joe.readData(empFile);
        sam.readData(empFile);
        mary.readData(empFile);

        empFile.close();

        //Call the printCheck( ) function for each of the three new objects, just as you did in the previous project.

        //I'll leave it to you to add this yourself.
    }
    else
    {
        system("CLS");      
        std::cout << "Incorrect entry.... Please try again and follow directions closely! \n" << std::endl;
        system("PAUSE");
        return 0;
    }
    return 0;
}
于 2013-06-02T10:29:41.940 回答