为什么要把父类的析构函数设置为virtual

本文探讨了C++中如何通过基类指针正确地释放子类对象的问题。重点介绍了虚析构函数的作用及其对多态删除的支持,并通过实例展示了不使用虚析构函数时子类析构函数不会被调用的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果我们想通过基类的指针去释放子类的对象(这里必须是new出来的对象),就需要基类将基类的虚函数设置为virtual,看下面的例子:

#include<iostream>
using namespace std;

class Parent
{
private:
	int m_a;
public:
	Parent(int a = 0)
	{
		this->m_a = a;
	}
	 ~Parent()
	{
		cout<<"parent destructor"<<endl;
	}
};

class Child:public Parent
{
private:
	int m_c;
public:
	Child(int c = 0)
	{
		this->m_c = c;
	}
	~Child()
	{
		cout<<"child destructor"<<endl;
	}
};

void del(Parent *base)//基类指针
{
	delete base;
}

void main()
{
	Parent *p_a = new Parent;
	Child *c_a = new Child;

	del(p_a);
	del(c_a);

	system("pause");
}

发现在调用del函数进行空间释放的时候,当传入子类的对象时候,子类的对象的析构函数并没有调用。要想通过基类的指针释放通过子类对象,必须将父类(基类的)的析构函数设置为virtual。如下:

#include<iostream>
using namespace std;

class Parent
{
private:
	int m_a;
public:
	Parent(int a = 0)
	{
		this->m_a = a;
	}
	virtual ~Parent()
	{
		cout<<"parent destructor"<<endl;
	}
};

class Child:public Parent
{
private:
	int m_c;
public:
	Child(int c = 0)
	{
		this->m_c = c;
	}
	 ~Child()
	{
		cout<<"child destructor"<<endl;
	}
};

void del(Parent *base)//基类指针
{
	delete base;
}

void main()
{
	Parent *p_a = new Parent;
	Child *c_a = new Child;

	del(p_a);
	del(c_a);

	system("pause");
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值