虚析构函数解析

Ø       C++ 指出:当一个派生类对象通使用一个基针删除,而个基有一个非虚的析构函数,则结果是未定的。运行有代表性的后果是象的派生部分不会被销毁。如果一个要被另外一个类继承,而且用其指指向其子类对,如A* d = new B();(假定A是基B是从A承而来的派生),那(A)析构函数必是虚的,否delete dB的析构函数将不会被用,因而会生内存泄漏和异常;

Ø       构造函数工作方式:在构造一个,先构造其基象,即用其基的构造函数,然后用本的构造函数;

Ø       析构函数的工作方式是:最底层的派生类(most derived class)的析构函数最先被调用,然后调用每一个基类的析构函数。

分析以下实例:

虚析构函数解析_第1张图片

 

 

     如果ClassB中不是虚析构函数,类B的对象pB在Delete时只能调用B的析构函数。当ClassB中是虚析构函数时。分析如下:

虚析构函数解析_第2张图片

结论:

Ø        带有多态性质基类,应该声明一个virtual析构函数。如果类中有任何虚函数,那么就应该将该类的析构函数定义成虚函数。

Ø         如果类的设计不是为了作为基类来使用,或者不是为了具备多态,就不应该声明虚析构函数。


注:以上均转自eric_jo的博客http://blog.csdn.net/eric_jo/article/details/4161480,

(有任何的疑问、看法或建议,请访问http://blog.csdn.net/eric_jo,留下你的宝贵意见。)




以下是个人总结和见解:

首先本文是在多态关系中已知析构函数与构造函数调用顺序的基础上,进一步说明:要想在 delete基类声明(派生类对象);时不产生内存溢出问题的话,就需要调用基类和派生类的析构函数,这样的话,基类的析构函数就需要声明为虚函数(virtual)。只有这样,派生类对象的虚函数表才会拷贝到基类对象的虚函数表,所以在 delete 基类声明(派生类对象);时才会使两者的析构函数得以调用。



你可能感兴趣的:(C++)