当前位置: 首页 > news >正文

C++类的构造顺序

1. C++ 类成员与自身的构造和析构顺序

  1. 默认先构造类成员(类成员的构造顺序就是类成员在类中被书写的顺序),然后再构造类本身。参看 “测试代码 1”。
  2. 默认先析构类本身,然后再析构类成员(类成员的析构顺序就是类成员在类中被书写顺序的反顺序)。参看 “测试代码 1”。
  3. 如果类成员在类的构造函数中才被初始化,那么就是先调用类自身的构造函数,然后再按类成员在构造函数中的初始化顺序依次构造类成员。但是析构顺序总是先析构类本身,然后再析构类成员(类成员的析构顺序就是类成员在类中被书写顺序的反顺序)。参看 “测试代码 2”。
  4. 可以使用智能指针,并在类的析构函数中调用智能指针的reset函数显式更改类成员之间的析构顺序,以及类成员和类本身的析构顺序。参看 “测试代码 3”。

1.1. 测试代码 1

#include<iostream>usingnamespacestd;classA{public:A(){cout<<"constructor A"<<endl;}~A(){cout<<"destructor A"<<endl;}};classB{public:B(){cout<<"constructor B"<<endl;}~B(){cout<<"destructor B"<<endl;}};classC{public:C(){cout<<"constructor C"<<endl;}~C(){cout<<"destructor C"<<endl;}private:A a;B b;};intmain(){C c;return0;}

输出:

constructor A constructor B constructor C destructor C destructor B destructor A

1.2. 测试代码 2

#include<iostream>#include<memory>#include<utility>usingnamespacestd;classA{public:A(){cout<<"constructor A"<<endl;}~A(){cout<<"destructor A"<<endl;}};classB{public:B(){cout<<"constructor B"<<endl;}~B(){cout<<"destructor B"<<endl;}};classC{public:C(){cout<<"constructor C"<<endl;b=std::make_unique<B>();a=std::make_unique<A>();}~C(){cout<<"destructor C"<<endl;}private:A a1;unique_ptr<A>a;unique_ptr<B>b;};intmain(){unique_ptr<C>c=std::make_unique<C>();return0;}

输出:

constructor A constructor C constructor B constructor A destructor C destructor B destructor A destructor A

1.3. 测试代码 3

#include<iostream>#include<memory>#include<utility>usingnamespacestd;classA{public:A(){cout<<"constructor A"<<endl;}~A(){cout<<"destructor A"<<endl;}};classB{public:B(){cout<<"constructor B"<<endl;}~B(){cout<<"destructor B"<<endl;}};classC{public:C(){cout<<"constructor C"<<endl;a=std::make_unique<A>();b=std::make_unique<B>();}~C(){cout<<"destructor C"<<endl;a.reset();b.reset();}private:unique_ptr<A>a;unique_ptr<B>b;};intmain(){unique_ptr<C>c=std::make_unique<C>();return0;}

输出:

constructor C constructor A constructor B destructor C destructor A destructor B

2. C++ 父类和子类的构造和析构顺序

对象在创建时构造函数的调用顺序:

  1. 调用父类的构造函数;
  2. 调用成员变量的构造函数;
  3. 调用类自身的构造函数。

子类对象析构时的顺序(析构函数的调用顺序与构造函数相反):
2. 执行自身的析构函数;
3. 执行成员变量的析构函数;
4. 执行父类的析构函数。

http://www.jsqmd.com/news/119392/

相关文章:

  • C++学习路径(C基础上)
  • (稀缺资源)Open-AutoGLM内部测试数据曝光:准确率高达99.7%的实测报告
  • C++函数指针 类成员函数指针
  • UE:材质基础知识之if判断节点
  • C++两个冒号不同用法的含义区别
  • Python硬件检测CPU、内存、显卡、硬盘等硬件信息获取
  • Open-AutoGLM待办同步架构深度拆解,99%的人都忽略的关键节点
  • 还在手动查体检报告?Open-AutoGLM自动查询方案来了,效率提升90%!
  • 错过服药时间危险有多大?Open-AutoGLM用时序推理帮你规避风险
  • Flink2.1.1-传感器温度计算示例
  • 【AI摄影革命】:Open-AutoGLM如何重新定义标准证件照生产流程
  • 告别反复重拍,Open-AutoGLM让你一次过审:国家级证件照生成实战解析
  • 心电信号ECG去噪:Matlab实现低通滤波与小波分解结合
  • 【医疗AI新突破】:Open-AutoGLM如何实现个性化用药提醒?
  • 【AI+医疗新突破】:Open-AutoGLM实现秒级挂号预约的5个关键步骤
  • YOLOv11 改进 - C2PSA | C2PSA融合DiffAttention差分注意力:轻量级差分计算实现高效特征降噪,提升模型抗干扰能力
  • 2025年度微动开关实力厂家推荐榜单,电动推杆微动开关/小型微动开关/微动开关/汽车微动开关/微动开关订制厂家推荐榜单 - 品牌推荐师
  • 【企业级保险监控方案】:基于Open-AutoGLM的7×24小时到期预警系统搭建
  • JavaSE——方法注意事项
  • JavaSE——方法注意事项
  • 体检报告查询进入AI时代:Open-AutoGLM究竟带来了哪些颠覆性变革?
  • Open-AutoGLM收益查询避坑指南(资深工程师亲授6大核心要点)
  • 12.21 模拟赛
  • 从语音到纪要全自动,Open-AutoGLM让会议效率提升8倍,你用了吗?
  • Open-AutoGLM实战指南:7步搭建企业级智能会议纪要系统
  • Flink2.1.1-WordCount示例
  • 【Open-AutoGLM收益监控终极方案】:5分钟搭建实时收益提醒系统
  • Flink2.1.1-docker安装
  • Open-AutoGLM会议纪要黑科技(90%团队还不知道的AI提效神器)
  • 校园IT负责人必看:Open-AutoGLM如何解决传统预约系统的4大痛点?