C++虚析构函数基本内容概述

C++的多态性是通过虚函数来实现的,虚函数的出现使得动态链接成为可能。

基于构造函数的特点,不能将构造函数定义为虚函数,但可以将析构函数定义为虚函数。当派生类的对象从内存中撤销时,会先调用派生类的析构函数,然后自动调用基类的析构函数,如此看来析构函数也没有必要定义为虚函数。

但是考虑如下这种情况,如果使用基类指针指向派生类的对象,而这个派生类对象恰好是用new运算创建的,这种情况下会如何呢?当程序使用delete运算撤销派生类对象时,这时只会调用基类的析构函数,而没有调用派生类的析构函数。如果使用的是虚析构函数的话,就不一样了,所以定义虚析构函数有时候还是很有必要的。下面这段程序就说明了上面的问题:

没有定义虚C++虚析构函数时,code如下:

 
 
  1. #include < iostream>
  2. using namespace std;
  3. class A
  4. {
  5. public:
  6. A(){}
  7. ~A()
  8. {
  9. cout< < "A::destructor"< < endl;
  10. }
  11. };
  12. class B:public A
  13. {
  14. public:
  15. B(){}
  16. ~B()
  17. {
  18. cout< < "B::destructor"< < endl;
  19. }
  20. };
  21. int main()
  22. {
  23. A *pA = new B;
  24. //
  25. delete pA;
  26. return 0;
  27. }

输出的是A::destructor

这说明delete pA只是调用了基类A的析构函数,而没有调用子类B的析构函数,这不是我们所想要的。而把基类A的析构函数定义为虚函数后,就可以达到了我们所想要的效果了。code如下:

 
 
  1. #include < iostream>
  2. using namespace std;
  3. class A
  4. {
  5. public:
  6. A(){}
  7. virtual ~A()
  8. {
  9. cout< < "A::destructor"< < endl;
  10. }
  11. };
  12. class B:public A
  13. {
  14. public:
  15. B(){}
  16. ~B()
  17. {
  18. cout< < "B::destructor"< < endl;
  19. }
  20. };
  21. int main()
  22. {
  23. A *pA = new B;
  24. //
  25. delete pA;
  26. return 0;
  27. }

输出如下:

B::destrutor

A::destrutor

以上就是对C++虚析构函数的相关介绍。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值