虚析构函数

这篇博客探讨了在C++中为什么需要将析构函数声明为虚函数。通过一个示例,展示了当基类指针指向派生类对象时,如果没有使用虚析构函数,会导致只有基类的析构函数被调用,而派生类的析构函数不会执行,从而可能导致内存泄漏。正确的做法是声明基类的析构函数为虚函数,确保在删除对象时能正确调用到派生类的析构函数。
摘要由CSDN通过智能技术生成

有时候,删除对象的时候需要进行多态,这个时候就需要将析构函数声明为虚函数。
有问题的代码:

#include <iostream>
using namespace std; 
class Base {
public:
    ~Base(); //不是虚函数
};
Base::~Base() {
    cout<< "Base destructor" << endl;
 }
 
class Derived: public Base{
public:
    Derived(){ p = new int(0);};
    ~Derived(){}; //不是虚函数
private:
    int *p;
};
Derived::~Derived() {
    cout<< "Derived destructor" << endl;
 }
void fun(Base* base){
  delete base;
};

int main(){
  Base *b = new Derived();
  fun(b);
  return 0;
}

output:

Base destructor

代码的本意是func()可以删除Base类的对象以及所有Base类的派生类对象,但因为声明的时候:Base *b = new Derived();是按照Base类去声明,虽然指向的是Derived类对象,但在调用fun()函数的时候,依旧会调用Base类的析构

因此,与普通析构函数一样,需要让代码在执行期再确定fun(Base* base)的指向类型。
声明析构为虚函数:

#include <iostream>
using namespace std; 
class Base {
public:
    virtual ~Base(); 
};
Base::~Base() {
    cout<< "Base destructor" << endl;
 }
 
class Derived: public Base{
public:
    Derived(){ p = new int(0);};
    virtual ~Derived(); 
private:
    int *p;
};
Derived::~Derived() {
    cout<< "Derived destructor" << endl;
 }
void fun(Base* base){
  delete base;
};

output:

Derived destructor
Base destructor
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值