C++析构函数为什么要为虚函数

#include<iostream>
using namespace std;

class A{
  public:
      A(){cout<<"A被构造\n";}
      ~A(){cout<<"A被析构\n";}
};
class B:public A
{
  public:
      B(){cout<<"B被构造\n";}
      ~B(){cout<<"B被析构\n";}
};

int main()
{
      A *p=new B;
      delete p;
}


运行结果:

A被构造
B被构造
A被析构
Process returned 0 (0x0)   execution time : 0.973 s
Press any key to continue.



关键不在于释放内存,而在于析构对象。

C++ new /delete 除了分配内存外,还自动调用构造函数/析构函数
new 分配内存后,调用构在函数,构造对象
delete 释放内存后,调用析构函数,析构对象。

当然,如果派生类有指针成员,并在构造函数中分配内存,析构函数中释放内存。
那么,如果父类没有把析构函数声明为虚析构函数,
delete 的时候,由于指针类型是父类,对象类型是子类,
那么只调用了父类的析构函数;析构了,子类中的父类子对象(父类部分);
子类的析构函数没有机会调用,子类部分则没有析构。
由于子类部分没有析构,指针成员分配的内存就不会释放。
这样就会造成内存泄露。

如果是子类部分配了其他资源,并在析构函数中释放,则会造成资源泄露。


可以看出:只有在用基类的指针指向派生类的时候,才会出现这种情况。因为这个时候虚函数发挥了动态的作用。

析构函数执行时先调用派生类的析构函数,其次才调用基类的析构函数。如果析构函数不是虚函数,而程序执行时又要通过基类的指针去销毁派生类的动态对象,那么用delete销毁对象时,只调用了基类的析构函数,未调用派生类的析构函数。这样会造成销毁对象不完全。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值