现有一个基类,一个派生类。程序中使用基类指针指向一个派生类对象。
如果基类析构函数声明时有virtual 则会执行派生类析构函数,如果未使用virtual声明,则仅执行基类析构函数。
代码如下
#include <iostream>using namespace std;class Base {
public:Base (){cout << "基类构造函数" << endl;}virtual ~Base() {cout << "基类析构函数" << endl;}
};class Drived: public Base {
public:Drived(): Base() {cout << "派生类构造函数" << endl;}~Drived() {cout << "派生类析构函数" << endl;}
};int main()
{Base* basePtr = new Drived();delete basePtr;return 0;
}
基类声明为虚析构函数时程序输出如下
将基类析构函数的virtual声明删除,用作对比测试
#include <iostream>using namespace std;class Base {
public:Base (){cout << "基类构造函数" << endl;}~Base() {cout << "基类析构函数" << endl;}
};class Drived: public Base {
public:Drived(): Base() {cout << "派生类构造函数" << endl;}~Drived() {cout << "派生类析构函数" << endl;}
};int main()
{Base* basePtr = new Drived();delete basePtr;return 0;
}
基类未声明为虚析构函数时程序输出如下
使用场景:当使用基类指针指向实例化的派生类对象时,派生类析构函数有对派生类资源的管理,则应在基类析构函数声明时在前面添加virtual声明。否则程序将根据其指针类型,而不是指针指向类型执行析构函数。