目录
用静态指针数组模拟虚复制构造函数
思路解析
在C++中构造函数是用来初始化特定类体的函数,它具有专一性,不具有多态性,因此不可以重载,不可以声明成虚构造函数。那我们该怎么办呢?
我们可以在派生类中定义一个“可以返回基类指针”的成员函数,这一步就实现了“用基类的指针指向派生类的对象”。这样我们就可以用初始化的派生类来初始化基类。从最终结果来看,像是派生类构造函数覆盖了基类构造函数,但实际上,这个过程是由“用基类的指针指向派生类的对象”实现的。
代码示例
#include <iostream>
#include <string>
using namespace std;
class Cperson
{
private:
string name;
float height;
float weight;
public:
Cperson(string name, float height, float weight)
{
this->name = name;
this->height = height;
this->weight = weight;
}
virtual ~Cperson()
{
cout << "调用Cperson析构函数" << endl;
}
void ShowInf()
{
cout << this->name << "身高为" << this->height << ";体重为" << this->weight << endl;
}
};
class Cstudent :public Cperson
{
private:
int StudNumber;
public:
Cstudent(int StudNumber, float height, float weight, string name) :Cperson(name, height, weight)
{
this->StudNumber = StudNumber;
}
~Cstudent()
{
cout << "调用Cstudent的析构函数" << endl;
}
Cperson* GainAddress(const Cstudent &stud)
{
return new Cstudent(stud); // 使用默认构造函数即可实现对象的拷贝
}
};
int main()
{
Cstudent stud(7, 180.9, 89.9, "超级霸霸强");
Cperson *person = stud.GainAddress(stud);
person->ShowInf(); // 执行成功,我们用被初始化过的Cstudent对象stud来初始化基类,相当于我们用派生类的构造函数覆盖了基类的构造函数
Delete person;
}