C++ 虚析构函数

 基类析构函数不是虚析构函数

class Base
{
public:
	Base(){cout<<"base constructor"<<endl;}
	~Base(){cout<<"base destructor"<<endl;}
};
class Derived:public Base
{
public:
	Derived(){cout<<"derived constructor"<<endl;}
	~Derived(){cout<<"derived destructor"<<endl;}
};
int main()
{
	Base* p=new Base();
	p=new Derived();
	delete p;
	return 0;
} 

输出:

指针p是基类指针,即使它指向子类对象,delete指针p时,它也只调用基类析构函数

当指针就是子类指针时,delete p 会先调用子类析构函数,再调用基类析构函数,但这不是多态,因为指针本就是指向子类对象的

int main()
{
	Derived * p2=new Derived();
	delete p2;
	return 0;
} 

将基类的析构函数设为析构函数

class Base
{
public:
	Base(){cout<<"base constructor"<<endl;}
	virtual ~Base(){cout<<"base destructor"<<endl;}
};
class Derived:public Base
{
public:
	Derived(){cout<<"derived constructor"<<endl;}
	~Derived(){cout<<"derived destructor"<<endl;}
};
int main()
{
	Base* p=new Base();
	p=new Derived();
	delete p;
	return 0;
} 

将基类的析构函数声明为虚函数之后,派生类的析构函数也自动成为虚析构函数,在主函数中基类指针p指向的是派生类对象,当delete释放p指针所指向的存储空间时,会执行派生类的析构函数,派生类的析构函数执行完之后会紧接着执行基类的析构函数

注意:

构造函数不能是虚函数,因为虚函数的入口地址在虚函数表中,虚函数表的地址在类对象的内存中,对象还未建立,更没有分配内存,此时就无法去查询虚函数表因此也就无法得知该调用哪一个构造函数了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值