编程论坛
注册
登录
编程论坛
→
VC++/MFC
为什么要将父类的析构函数定义成虚函数
魅影晓月
发布于 2011-06-19 21:33, 845 次点击
如果直接delete子类对象,程序就会崩溃.....这到底是为什么?
3 回复
#2
Toomj
2011-06-20 00:11
不需要将父类的析构函数定义成虚函数啊
当派生类析构时,先调用派生类析构函数清理派生类新增成员,再调用派生类成员对象析构函数清理派生类新增的成员对象,最后调用基类析构函数清理从基类继承来的基类子对象。
#3
duliningmiss
2011-06-20 16:45
多态的时候一定要将析构函数写成虚函数,防止内存泄露,各个子类维护自己内部数据释放。
#4
duliningmiss
2011-06-20 16:46
给你举个例子,帮助理解吧
#include <iostream.h>
class Base
{
public:
Base() { mPtr = new int; }
~Base() { delete mPtr; cout<<"Base::Destruction"<<endl;}
private:
int* mPtr;
} ;
class Derived : public Base
{
public:
Derived() { mDerived = new long; }
~Derived() { delete mDerived; cout<<"Derived::Destruction"<<endl;}
private:
long* mDerived;
} ;
void main()
{
Base* p = new Derived;
delete p;
}
输出结果只有:Base::Destruction
以上代码会产生内存泄露,因为new出来的是Derived类资源,采用一个基类的指针来接收,析构的时候,编译器因为只是知道这个指针是基类的,所以只将基类部分的内存析构了,而不会析构子类的,就造成了内存泄露,如果将基类的析构函数改成虚函数,就可以避免这种情况,因为虚函数是后绑定,其实就是在虚函数列表中,析构函数将基类的析构函数用实际对象的一组析构函数替换掉了,也就是先执行子类的虚函数再执行父类的虚函数,这样子类的内存析构了,父类的内存也释放了,就不会产生内存泄露。
注:
1.析构函数其实是一个函数,不论子类还是父类,虽然可能看起来名字不一样。而且析构函数执行过程都是执行子类再到父类。
2.多态的时候一定要将析构函数写成虚函数,防止内存泄露,各个子类维护自己内部数据释放。
1