为什么要使用虚析构函数
- 举例
#include <iostream>
using namespace std;
class CSon {
public:~CSon(){cout<<"Son"<<endl;};
};
class CGrandson:public CSon {
public:~CGrandson(){cout<<"CGrandson"<<endl;};
};
int main(int argc, const char * argv[]) {
//基类指针指向 派生类对象
CSon *p = new CGrandson;
//调用析构函数的时候会调用基类的析构函数,而没有调用派生类的析构函数,这样会导致垃圾内存的出现
delete p;
return 0;
}
打印: Son
- 存在的问题
实际上创建的是一个派生类的对象,但是调用的却是基类的析构函数。
虚析构函数所解决的问题
- 通过基类的指针删除派生类的对象时->只调用基类的析构函数
- 删除一个派生类的对象时候
->先调用 派生类的析构函数
->再调用 基类的析构函数
虚析构函数
- 解决办法:
- 把基类析构函数声明为 virtual
- 实例:
修改上面例子,将基类的析构函数声明为虚析构函数:
#include <iostream>
using namespace std;
class CSon {
public:virtual~CSon(){cout<<"Son"<<endl;};
};
class CGrandson:public CSon {
public:~CGrandson(){cout<<"CGrandson"<<endl;};
};
int main(int argc, const char * argv[]) {
//基类指针指向 派生类对象
CSon *p = new CGrandson;
//调用析构函数的时候会调用基类的析构函数,而没有调用派生类的析构函数,这样会导致垃圾内存的出现
delete p;
return 0;
}
调用结果
CGrandson
Son
这样就实现了先析构派生类对象,再析构基类。