如果没有继承关系,析构函数写不写为虚函数都可以。
如果有继承关系、有多态性的使用需求时,就需要把析构函数写为虚函数,这样可以避免潜在的内存泄漏问题。
比如:当一个类被设计为作为基类,并且通过基类指针或引用delete派生类对象,这种情况下,如果没有把析构函数写为虚函数,因为delete是先调用析构函数再释放内存空间,此时就只会调用基类的析构函数,造成了析构不完全,容易引发内存泄漏。
#include <iostream>
using namespace std;
class Parent{
public:
Parent(){
cout << "Parent construct function" << endl;
};
virtual ~Parent(){
cout << "Parent destructor function" <<endl;
}
};
class Son : public Parent{
public:
Son(){
cout << "Son construct function" << endl;
};
~Son(){
cout << "Son destructor function" <<endl;
}
};
int main()
{
Parent* p = new Son();
//基类指针或引用delete派生类对象
delete p;
p = NULL;
return 0;
}
以上代码运行时,按如下方式:
调用父类构造
调用子类构造
delete时会先调用析构函数再释放内存空间,由于是父类指针调用虚函数,且实现了虚函数重写,所以这里会构成多态调用,最终会调用子类的析构函数,在子类析构函数结束时会自动调用父类析构函数
如果父类的析构函数没有声明为虚函数,那么delete时就只是一个普通的成员函数调用,只会调用父类的析构函数,造成析构不完全,在子类有指向外部的资源时(heap),会引发内存泄漏问题。