c++虚析构函数

虚析构函数是提供动态调用子类析构函数的方式。

代码如下:

#include "stdafx.h"
#include <iostream>
using namespace std;

class A
{
public:
	A()
	{
		printf("A()\n");
	}
	virtual ~A()
	{
		printf("~A()\n");
	} 
};

class B:public A
{
public:
	B()
	{
		printf("B()\n");
	}
	~B()
	{
		printf("~B()\n");
	}
};

int main(int argc, _TCHAR* argv[])
{
	A *a = new B();
	a->~A();
	return 0;
}


结果如下:


c++虚析构函数_第1张图片

如果没有virtual ~A(),就不会调用B的析构函数,new出来的内存没有及时回收造成内存泄漏。a->~A(),实际上调用直接调用类A的虚的析构函数和使用delete a 效果是一样的(前提是析构函数是虚的,否则效果是两者都没有调用类B 的虚构函数)。


虚析构函数中,~B()重载了~A(),指向派生类的指针就能根据运行时的状态调用B的析构函数,并且子类的析构函数执行结束后会调用父类的析构函数。


虚函数和普通成员函数的区别,是虚函数放在虚函数表中,通过对象的this指针找到该类的虚函数表,然后调用。C++即采用此机制实现多态。

如果是普通函数,每个函数的地址是死的。所以用A类的对象调用析构函数时只能调到A的析构。如果是虚函数,则会通过指针找到B的析构函数,而B继承自A,还会调用A的析构函数。


因为当类里面有虚函数的时候,编译器会给类添加一个虚函数表,表里面来存放虚函数地址,每个类对象的首地址有一个指向虚函数表的地址,这样就会增加对象的内存空间。只有当一个类被用来作为基类的时候,才把析构函数写成虚函数。




你可能感兴趣的:(c++虚析构函数)