虚析构函数的理论前提是
执行完子类的析构函数,那么父类的虚构函数必然会被执行。
那么当用delete释放一个父类指针所实例化的子类对象时,如果没有定义虚析构函数,那么将只会调用父类的析构函数,而不会调用子类的虚构函数,导致内存的泄漏。
Class Shape
{
public:
virtual Shape();
~Shape();
private:
int m_ir;
};
Class Circle:public Shape
{
public:
Circle();
~Circle();
private:
int m_ir;
};
int main()
{
Shape *shape=new Circle;
delete shape;
shape=NULL;
}
如果基类中定义了虚析构函数,那么在Shape的虚函数表中就会存放虚析构函数的地址
而编译器会自动帮派生类的析构函数前加上virtual关键字。
那么实例化Circle时,在Circle的虚函数表中也会存放Circle的虚析构函数的地址。在执行delete shape时,在Circle的虚函数表中找到虚析构函数的地址,执行析构函数,释放派生类占用的内存,而派生类的析构函数被调用那么基类的析构函数也会自动被调用。