考虑这样一个问题,有两个类,
class A;
class B : public A;
定义了这样一个对象:A* pA = new B();
这时在delete pA;时,调用的是A的析构函数,但问题是,我们定义的对象是B的对象,而要B来析构。因而就要在A中定义一个虚的析构函数,这样由于运行时多态,都会调用B中定义的析构函数。否则就要delete (B*)pA;来强制类型转换,如果A有多个子类,在运行时实际上是不知道这时是哪个子类的,因而强制转换的方法实际上是不科学的。如果将A中的析构函数定义成了virtual,那么在析构时,就会选调用B的析构函数,再调用A的析构函数,这是可以理解的,因为有些属性是A中的属性,B中不一定可见,就无法处理。