继承/组合关系时 构造/析构函数执行顺序 虚析构函数存在的意义

本文通过C++示例代码展示了在继承与组合关系中构造函数与析构函数的执行顺序,并解释了虚析构函数的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

继承/组合关系时 构造/析构函数执行顺序

#include <iostream>
using namespace std;
class A{
public:
    A(){
        cout<<"A"<<endl;
    }   
    ~A(){
        cout<<"~A"<<endl;
    }   
};
class B:public A{
public:
    B(){
        cout<<"B"<<endl;
    }   
    ~B(){
        cout<<"~B"<<endl;
    }   
};
class C:public B{
public:
    C(){
        cout<<"C"<<endl;
    }   
    ~C(){
        cout<<"~C"<<endl;
    }   
};
class D{
private:
    C c;
public:
    D(){
        cout<<"D"<<endl;
    }
    ~D(){
        cout<<"~D"<<endl;
    }
};
int main(){
    cout<<"继承关系:A<-B<-C"<<endl;
    C c;
    cout<<"组合关系: D包含C对象成员"<<endl;
    D d;

输出

(base) ➜  Cpp ./constructSequence        
继承关系:A<-B<-C
A
B
C
组合关系: D包含C对象成员
A
B
C
D
~D
~C
~B
~A
~C
~B
~A

虚析构函数存在的意义

#include <iostream>
using namespace std;
class father{
public:
    virtual ~father(){
        cout<<"desFather"<<endl;
    }   
    virtual void func(){
        cout<<"father virFunc"<<endl;
    }   
};
class son:public father{
public:
    virtual ~son(){
        cout<<"desSon"<<endl;
    }   
    virtual void func(){
        cout<<"son virFun"<<endl;
    }   
};
int main(){
    father *f = new son; 
    f->func();
    delete f;
    return 0;
}

输出:

(base) ➜  Cpp ./virtualDes                    
son virFun
desSon
desFather

如果析构函数不是虚函数,那么只释放父类,不释放子类。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

t0tott

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值