类的实例只允许1个方法或程序崩溃

Instance of class only allows 1 method, or program crashes

本文关键字:方法 程序 崩溃 1个 实例      更新时间:2023-10-16

我正在学习类和OOP,所以我在做一些练习程序时,在编程时遇到了有史以来最奇怪的错误。

因此,我有以下文件,以我的类"pessoa"开头,位于pessoa.h:

#pragma once
#include <string>
#include <iostream>
using namespace std;
class pessoa {
public:
//constructor (nome do aluno, data de nascimento)
pessoa(string newname="asffaf", unsigned int newdate=1996): name(newname), DataN(newdate){};
void SetName(string a); //set name
void SetBornDate(unsigned int ); //nascimento
string GetName(); //get name
unsigned int GetBornDate();
virtual void Print(){}; // print
private:
string name; //nome
unsigned int DataN; //data de nascimento
};

其功能在pessoa.cpp 中定义

#include "pessoa.h"
string pessoa::GetName ()
{
    return name;
}
void pessoa::SetName(string a)
{
    name = a;
}
unsigned int pessoa::GetBornDate()
{
    return DataN;
}
void pessoa::SetBornDate(unsigned int n)
{
    DataN=n;
}

函数DoArray在DoArray.h中声明,并在文件DoArray.cpp:中定义

    pessoa** DoArray(int n)
{
    pessoa* p= new pessoa[n];
    pessoa** pointer= &p;
    return pointer;
}

主文件:

#include <string>
#include <iostream>
#include "pessoa.h"
#include "DoArray.h"
#include <cstdio>
using namespace std;
int main()
{
//pessoa P[10];
//cout << P[5].GetBornDate();
pessoa** a=DoArray(5);
cerr << endl << a[0][3].GetBornDate() << endl;
cerr << endl << a[0][3].GetName() << endl;

    return 0;
}

奇怪的发现是,如果我对上面的一个方法"GetBornDate"或GetName进行注释并运行,则未注释的方法将正常运行。但是,如果两者都没有被注释,那么第一个方法将运行,程序将在第二个方法之前崩溃。

抱歉发了这么长的邮件。

让我们来看看这个函数:

int *get()
{
    int i = 0;
    return &i;
}

它有什么问题?它返回指向局部变量的指针,当函数get()终止时,局部变量不再存在,即返回悬空指针。现在您的代码:

 pessoa** DoArray(int n)
 {
     pessoa* p= new pessoa[n];
     return &p;
 }

你看到问题了吗?

进一步澄清:

 typedef pessoa * pessoa_ptr;
 pessoa_ptr* DoArray(int n)
 {
     pessoa_ptr p= whatever;
     return &p;
 }

您需要明白,无论您分配给p什么都不会改变p本身的生存期。指针与其他指针是相同的变量。