基类析构函数为virtual的好处

class Base
{
public:
    ~Base(){...}
    ... 
};
class Child:public Base
{
public:
    ~Child(){...}
};
int main()
{
    Child c;
    ...
    return 0;
}

上面代码运行时,在生成Child对象c时,实际上先调用基类Base的构造函数,然后再调用Child类的构造函数。当撤销c时,先调用Child的析构函数,然后在调用Base的析构函数,也就是说,无论基类的析构函数是否为虚构函数,肯定会依次调用其基类的析构函数。根本原因:上面所有对象都存在于栈中,当其离开作用域时,该对象会被自动撤销。
然而为什么还要搞个虚构函数呢?
这是因为多态的存在。

Base *pBase;
Child c;
pBase =& c;

那么,当pBase被撤销时呢?如果Base的析构函数不是virtual,那么根据静态联编,显然会调用Base的析构函数,而不会调用Child类的析构函数。而如果Base的析构函数改为virtual,当pBase指针被撤销时,就会先调用Child类析构函数,再调用Base类的析构函数。根本原因:上面过程是动态联编,在堆中进行,如果不将基类析构函数设置为virtual,则会造成内存泄露。基类析构函数设置为virtual后,所有派生类的析构函数都将会是virtual。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值