虚析构函数的实现原理

虚析构函数的理论前提是

执行完子类的析构函数,那么父类的虚构函数必然会被执行。

那么当用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的虚函数表中就会存放虚析构函数的地址

虚析构函数的实现原理_第1张图片
而编译器会自动帮派生类的析构函数前加上virtual关键字。
那么实例化Circle时,在Circle的虚函数表中也会存放Circle的虚析构函数的地址。在执行delete shape时,在Circle的虚函数表中找到虚析构函数的地址,执行析构函数,释放派生类占用的内存,而派生类的析构函数被调用那么基类的析构函数也会自动被调用。
虚析构函数的实现原理_第2张图片

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