当用new运算符建立了临对象,若基类中有析构函数,并且定义了一个指向该基类的指针变量,在程序用带指针参数的delete运算符撤销对象时,会发生一个情况,系统只执行基类的析构函数,而不执行派生类的析构函数。原因是指针只找到了空间中与基类类型相同的部分,自然只调用基类的析构函数,可以看下面的例子:
#include<iostream>
using namespace std;
class A
{
public :
A ()
{a=0;}
~A(){cout<<"exeecuting A desturctor"<<endl;}
private :
int a;
};
class B:public A
{
public :
B()
{b=1;}
~B(){cout<<"executing B destructor"<<endl;}
private :
int b;
};
void main()
{
A *p=new B;
delete p;
}
输出:exeecuting A desturctor
如果希望执行派生类的析构函数·,则应该把基类的析构函数声明为虚析构函数。
此时与基类关联的所有派生类的析构函数都自动变为虚析构函数。
在程序中最好把基类的析构函数声明为虚析构函数。以保证在撤销内存动态分配空间时能得到正确的处理。