析构函数:
1.析构函数不能被重载;
2.析构函数可以是虚函数;
3.析构函数没有参数,没有返回值;
4.当类对象的生命周期结束,系统会自动调用析构函数;
5.若没有显式的析构函数,系统会调用默认的析构函数;
下面记录一下一个小示例,目的是说明虚析构函数的必要性。若析构函数不是虚函数,会发生什么,vs2010下创建控制台输出程序,下面看代码,以及运行实例;
classObject.cpp
#include "stdafx.h"
#include <iostream>
using namespace std;class Base
{
public:Base(){cout<<"构造函数Base()"<<endl;};~Base(){cout<<"析构函数~Base()"<<endl;}//基类的析构函数不是虚析构函数
protected:
private:
};class Inherit:public Base
{
public:Inherit(){cout<<"构造函数Inherit()"<<endl;}~Inherit(){cout<<"析构函数Inherit()"<<endl;}
protected:
private:
};int _tmain(int argc, _TCHAR* argv[])
{Base *base = new Inherit;delete base;//下面3行代码是一个小插曲,作者记录下来巩固基础int a[] = {12,13,23,4,5};cout<<"sizeof(*a)="<<sizeof(*a)<<endl;cout<<"*a="<<*a<<endl;//*a是数组a的第一个元素,sizeof(*a)即整型的大小 4system("pause");return 0;
}
运行上面的代码,控制台输出结果是:
可以看出析构函数调用的时候只调用了,父类的析构函数,没有调用子类的析构函数,即没有释放子类的对象,无形中造成内存泄漏,下面我们来将父类的析构函数定义为虚析构,即在父类的析构函数前加关键字virtual,将父类析构函数改为下面这样,其它不变。
Base(){cout<<"析构函数Base()"<<endl;}//基类的析构函数是虚析构函数
编译运行程序,结果如下:
总结:当一个类作为父类的时候,最好将此类的析构函数定义为虚析构函数。