首先看看下面这个简单的代码:
#include<string>
#include<iostream>
using namespace std;
class Pet
{
public:
Pet();
~Pet();
// virtual ~Pet();
int i;
};
class Dog:public Pet
{
public:
Dog();
~Dog();
// virtual ~Dog();
int j;
};
Pet::Pet():i(1)
{
cout<<"new Pet"<<endl;
}
Pet::~Pet()
{
cout<<"delete Pet"<<endl;
}
Dog::Dog()
{
cout<<"new Dog"<<endl;
j=0;
}
Dog::~Dog()
{
cout<<"delete Dog"<<endl;
}
int main()
{
Pet *p=new Dog;
cout<<p->i<<endl;
//cout<<p->j<<endl;
delete p;
return 0;
}
注意
Pet *p=new Dog;
。。。。
delete p;
当基类中的析构函数没有被标示为virtual时,只有基类的析构函数被调用,如果基类的析构函数被标示为virtual,那么当用delete作用于P时dog类的析构函数将被调用,同时自动调用基类的析构函数.
由此可见只要基类的析构函数标示为virtual,那么所有占用的内存空间都将被释放,为防范如上的不测事件,没有释放所有的内存空间,最好是把析构函数标示为虚函数。