虚析构和纯虚析构

本文讨论了在C++中,当子类对象通过父类指针进行创建和释放时,由于默认情况下析构函数是非虚函数,可能会导致子类的析构代码无法被调用,从而引起内存泄漏。解决方案是将父类的析构函数声明为虚析构或纯虚析构。通过实例展示了如何使用虚析构函数确保正确释放子类资源,避免内存问题。
摘要由CSDN通过智能技术生成

多态使用时,如果子类中有属性开辟到堆区,那么父类指针在释放时无法调用到子类的析构代码,会出现内存泄漏的问题

解决方法: 将父类中的析构函数改为虚析构或者纯虚析构

虚析构和纯虚析构共性:

  • 可以解决父类指针释放子类对象
  • 都需要有具体的函数实现

虚析构和纯虚析构的区别:

  • 如果是纯虚析构,该类属于抽象类,无法实例化对象

案例

class Animal {
public:
    Animal()
    {
        cout << "Animal 的构造" << endl;
    }
    virtual void speak()
    {
        cout  << "动物" << endl;
    }

	// 虚析构函数
    // virtual ~Animal()
    // {
    //     cout << "Animal 的析构函数" << endl;
    // }

    // 纯虚析构函数 需要在外部有实现的函数体
    // 有了纯虚析构之后,这个类也属于抽象类,无法实例化对象
    virtual ~Animal() = 0;
};

Animal:: ~Animal()
{
    cout << "Animal 的析构" << endl;
}

class Cat : public Animal
{
public:
    Cat(string name)
    {
        cout << "Cat 的构造" << endl;
        nName = new string(name);
    }

    void speak()
    { cout << *nName << " 猫" << endl; }

    ~Cat()
    {
        if (nName) {
            cout << "Cat 析构" << endl;
            delete nName;
            nName = nullptr;
        }
    }
};

void test()
{
    Animal *ani = new Cat("Tom");
    ani->speak();
    // 子类中有属性开辟到堆区,那么父类指针在释放时无法调用到子类的析构代码,会出现内存泄漏的问题,需要将父类中的析构函数改为 虚析构 或者 纯虚析构
    delete ani;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值