析构函数定位虚函数的作用

析构函数定位虚函数的作用
当一个继承类经由一个基类的指针删除时,而该基类包含的是一个非虚析构函数,其结果是未定义的(实际执行时通常发生的是继承类的独有成分没有被销毁)。这个后果很严重,会造成**内存泄漏**。

通过基类指针删继承类时,需要特别注意!!

/*
* 当一个继承类经由一个基类的指针删除时,而该基类包含的是一个非虚析构函数,
* 其结果是未定义的(实际执行时通常发生的是继承类的独有成分没有被销毁)。
* 这个后果很严重,会造成内存泄漏。
*
* 通过基类指针删继承类时,需要特别注意!!
*/

#include <iostream>
using namespace std;

class Base{
public:
    Base (){
        cout<<"Base 构造函数执行了!"<<endl;
    }
    virtual ~Base(){
        cout<<"Base 析构函数执行了!"<<endl;
    }
    virtual void func(){
        cout<<"Base::func 虚函数执行了!"<<endl;
    }
};
class Derived :public Base
{
public:
    Derived(){
        cout<<"Derived 构造函数执行了!"<<endl;
    }
    ~Derived(){
        cout<<"Derived 析构函数执行了!"<<endl;
    }
    virtual void func(){
        cout<<"Derived::func 虚函数执行了!"<<endl;
    }
};

int main()
{
    Base *p;
    p=new Derived;
    p->func();

    delete  p;      //!此时只会执行Base的析构函数,不会执行Dervied的析构函数,从而导致内存泄露;
                        //!解决方法==>>将基类的析构函数定义为虚函数;
    return 0;
}

//------------------------------------输出信息-----------------------------------//
Base 构造函数执行了!               //先构造基类
Derived 构造函数执行了!            //再构造继承类
Derived::func 虚函数执行了!
Derived 析构函数执行了!            //先析构继承类
Base 析构函数执行了!               //在析构子类

//------------------------------------主函数修改-----------------------------------//
int main()
{
    Derived d;
    d.func();
}
//------------------------------------输出信息-----------------------------------//
Base 构造函数执行了!
Derived 构造函数执行了!
Derived::func 虚函数执行了!
Derived 析构函数执行了!
Base 析构函数执行了!

//==>> 局部对象在声明结束时自动析构;
//==>> 在构造对象的时候,先构造基类,再构造继承类;在析构的时候,先析构继承类,再析构基类;即先构造的后析构;

//------------------------------------主函数修改-----------------------------------//
int main()
{
    Derived *d2=new Derived;
    d2->func();
}
//------------------------------------输出信息-----------------------------------//
Base 构造函数执行了!
Derived 构造函数执行了!
Derived::func 虚函数执行了!

//==>> 不会执行析构函数!!
//==>> 所以,通过new在堆上划分的内存必须需要通过手动释放,不然会导致内存泄露!!==>delete d2;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值