好记性不如烂笔头1——基类的析构函数要声明为虚函数

要弄清楚“为什么基类的析构函数要声明为虚函数”,首先要清楚基类、子类构造函数和析构函数的执行顺序。构造函数的执行顺序为先执行基类的构造函数、再执行子类的构造函数;析构函数的执行顺序为先执行子类的析构函数,再执行基类的析构函数

 

如果在基类的析构函数没有声明为虚函数,则在下面这种情况,会有问题

#include <iostream>
#include <windows.h>
using namespace std;

class CBase
{
public:
	CBase()
	{
		std::cout << "CBase" << endl;
	}

	~CBase()
	{
		std::cout << "~CBase" << endl;
	}

private:
	int m_iPara;
};

class CChild : public CBase
{
public:
	CChild()
	{
		std::cout << "CChild" << endl;
	}

	~CChild()
	{
		std::cout << "~CChild" << endl;
	}

private:
	int m_iPara;
};

int main()
{
	CBase* p = new(std::nothrow) CChild();
	if (nullptr != p)
	{
		delete p;
		p = nullptr;
	}
	system("pause");
}

运行结果为

可以看到,子类的析构函数没有执行。一个类的析构函数往往和构造函数相对应,构造函数负责一些初始化,析构函数进行反初始化操作,而子类的析构函数没有执行的话,子类析构函数的反初始化操作(往往是一些内存等资源的释放等)就没有执行,从而造成程序异常。

 

基类的析构函数声明为虚函数后

#include <iostream>
#include <windows.h>
using namespace std;

class CBase
{
public:
	CBase()
	{
		std::cout << "CBase" << endl;
	}

	virtual ~CBase()
	{
		std::cout << "~CBase" << endl;
	}

private:
	int m_iPara;
};

class CChild : public CBase
{
public:
	CChild()
	{
		std::cout << "CChild" << endl;
	}

	~CChild()
	{
		std::cout << "~CChild" << endl;
	}

private:
	int m_iPara;
};

int main()
{
	CBase* p = new(std::nothrow) CChild();
	if (nullptr != p)
	{
		delete p;
		p = nullptr;
	}
	system("pause");
}

运行结果为

可以看到子类及基类的析构函数都被正常执行了

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值