派生类析构函数举例(多继承、含有嵌入对象)

#include <iostream>

using namespace std;

class B1
{
public:
    B1(int i){cout<<"coustructing B1 "<<i<<endl;}
    ~B1(){cout<<"destructing B1"<<endl;}
};
class B2
{
public:
    B2(int j){cout<<"coustructing B2 "<<j<<endl;}
    ~B2(){cout<<"destructing B2"<<endl;}
};
class B3
{
public:
    B3(){cout<<"coustructing B3 *"<<endl;}
    ~B3(){cout<<"destructing B3"<<endl;}
};
class C:public B2,public B1,public B3
{
public:
    C(int a,int b, int c, int d):B1(a),memberB2(d),memberB1(c),B2(b){}
private:
    B1 memberB1;
    B2 memberB2;
    B3 memberB3;
};
int main()
{
    C obj(1,2,3,4);
    return 0;
}


程序在执行时,首先执行派生类的构造函数,然后执行派生类的析构函数。构造函数部分我们已经讨论过了,派生类默认的析构函数又分别调用了成员对象及基类的析构函数,这次的次序刚好和构造函数执行时严格相反,看程序的运行结果如下:

### C++派生类析构函数的继承行为和调用顺序 在C++中,派生类析构函数与构造函数一样遵循特定的调用顺序。对于析构函数,其调用顺序与构造函数相反。具体来说,当一个派生类对象被销毁,首先调用派生类析构函数,然后依次调用基类的析构函数[^1]。 以下是详细的规则和示例代码说明: - 在单继承关系中,当派生类对象被销毁析构函数的执行顺序为:**派生类析构函数 → 基类析构函数**。这意味着派生类的资源会先被释放,接着是基类的资源[^2]。 ```cpp class Base { public: ~Base() { std::cout << "Base destructor called." << std::endl; } }; class Derived : public Base { public: ~Derived() { std::cout << "Derived destructor called." << std::endl; } }; int main() { Derived obj; return 0; } ``` 运行结果: ``` Derived destructor called. Base destructor called. ``` - 如果派生类中包含其他成员对象(如嵌套的对象成员),则这些成员对象析构函数会在派生类析构函数之后、基类析构函数之前被调用[^4]。例如: ```cpp class Member { public: ~Member() { std::cout << "Member destructor called." << std::endl; } }; class Base { public: ~Base() { std::cout << "Base destructor called." << std::endl; } }; class Derived : public Base { Member m; public: ~Derived() { std::cout << "Derived destructor called." << std::endl; } }; int main() { Derived obj; return 0; } ``` 运行结果: ``` Derived destructor called. Member destructor called. Base destructor called. ``` - 关于显式调用基类析构函数的问题,在C++中,派生类析构函数会自动调用基类的析构函数,因此无需手动调用[^3]。如果基类的析构函数是虚函数,则可以确保通过指针或引用删除派生类对象,正确的析构函数链会被触发。 ### 注意事项 - 如果基类的析构函数不是虚函数,而通过基类指针删除派生类对象,可能会导致未定义行为。因此,建议将基类的析构函数声明为虚函数。 ```cpp class Base { public: virtual ~Base() { std::cout << "Base destructor called." << std::endl; } }; class Derived : public Base { public: ~Derived() { std::cout << "Derived destructor called." << std::endl; } }; int main() { Base* ptr = new Derived(); delete ptr; return 0; } ``` 运行结果: ``` Derived destructor called. Base destructor called. ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值