父类和子类调用析构函数的几个现象汇总

测试用例

#include <iostream>
using namespace std;//运算符的重载
class Person//人
{
public:
	int a;
	Person()
	{
		cout << "父类的不带参的构造函数调用" << endl;
	}
	Person(int a)
	{
		cout << "父类的带参数的构造函数调用" << endl;
	}
	~Person()
	{
		cout << "父类的析造函数调用" << endl;
	}
	void go()//父类
	{
		cout << "父类的go()" << endl;
	}
	void go(int a)//父类
	{
		this->a = a;
		cout << "父类的有参数的go()" << endl;
	}
};
//父类 = 基类  子类 = 派生类
class Student :public Person//学生,公有的继承
{
public:
	Student() :Person(10)//构造函数,继承父类
	{
		cout << "子类的构造函数调用" << endl;
	}
	~Student()
	{
		cout << "子类的析造函数调用" << endl;
	}
	void go()//重写这个go(),继承父类
	{
		cout << "子类的无参数的go()" << endl;
	}
	void go(int a)//重写这个go(),继承父类
	{
		cout << "子类的带参的go()" << endl;
	}
};

用两个对象,person父类,studen子类

父类 = new 子类

不调用delete函数

void main()
{
	Person* p = new Student();
	return;
}

结果:

父类的带参数的构造函数调用
子类的构造函数调用

调用delete函数,触发父类的析构函数

void main()
{
	Person* p = new Student();
	delete p;
	return;
}

结果:

父类的带参数的构造函数调用
子类的构造函数调用
父类的析造函数调用

如果:
p->go();
是触发调用父类的子函数

子类 = new 子类

void main()
{
	Student* p = new Student();
	return;
}
父类的带参数的构造函数调用
子类的构造函数调用

调用delete函数

void main()
{
	Student* p = new Student();
	delete p;
	return;
}
父类的带参数的构造函数调用
子类的构造函数调用
子类的析造函数调用
父类的析造函数调用

如果:
p->go();
是触发调用子类的子函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值