0

我创建了一个自定义类 Person,它从工作的角度保存有关人员的信息。

class Person
{
    char* _name;
    char* _lName;
    char* _department;
    int _age, _salary;
public:
    Person(char* name, char* lName, char* department, int age, int salary);
    Person(void);
    ~Person(void);

    char* getFName(){return _name;};
    char* getLName(){return _lName;};
    char* getDepartment(){return _department;};
    int getSalary(){return _salary;};

    friend std::ostream &operator<<(std::ostream &cout, Person &person);
    friend std::istream &operator>>(std::istream& is, Person &person);
};

我希望完成的是,使用 cin 以逗号分隔的 char* 的形式将数据流式传输到此类中。

cin 过载:

std::istream &operator>>(std::istream &is, Person &person)
{
    char* tmp="";
    is >> tmp;
    int i=0;
    int number=0;
    char** dataArray=new char*;
    dataArray[0]="";
    while(tmp[i]!= '\0')
    {
        if(tmp[i]==',')
        {
            number++;
            dataArray[number]="";
        }
        else
            dataArray+=tmp[i];
        i++;
    }
    person._name=dataArray[0];
    person._lName=dataArray[1];
    person._department=dataArray[2];
    person._salary=(int)dataArray[3];
    person._age=(int)dataArray[4];
    return is;
}

但是,程序在以下位置停止并出现错误;

  is >> tmp;

我以前根本没有操作过 istream,这个错误可能是由于错误的推理造成的。帮助将不胜感激。

4

1 回答 1

2

您需要在此处指定大小:

char** dataArray=new char*;

我认为你需要:

char** dataArray=new char*[5];

您泄漏了此变量的内存。您似乎正在操纵这个数组的元素,就好像它们是 一样std::string,但它们是简单的 char 数组。您需要分配和重新分配它们。为避免所有这些问题,请使用std::vectorand std::stringoperator<<你的错误与它本身无关。

于 2013-02-14T15:02:08.703 回答