C++构造函数和析构函数调用顺序详解
我们知道,每当创建一个类的对象时,编译器都会自动调用构造函数。由于派生类的每个对象都可以被认为具有嵌入其中的基类的对象,所以创建派生类对象涉及创建嵌入的基类对象。
编译器总是在调用派生类构造函数之前调用基类构造函数。这个顺序在派生类对象销毁时就刚好反过来,即派生类中的析构函数在基类的析构函数之前调用。
该顺序允许派生类的构造函数和析构函数在工作中使用基类的数据或成员函数。
下面的程序通过一个简单的程序演示了这种表现。
编译器总是在调用派生类构造函数之前调用基类构造函数。这个顺序在派生类对象销毁时就刚好反过来,即派生类中的析构函数在基类的析构函数之前调用。
该顺序允许派生类的构造函数和析构函数在工作中使用基类的数据或成员函数。
下面的程序通过一个简单的程序演示了这种表现。
// This program demonstrates the order in which base and //derived class constructors and destructors are called. #include <iostream> #include <memory> using namespace std; // Base class class BaseDemo { public: BaseDemo() // Constructor { cout << "This is the BaseDemo constructor. \n"; } virtual ~BaseDemo() // Destructor { cout << "This is the BaseDemo destructor.\n"; } }; // Derived class class DeriDemo : public BaseDemo { public: DeriDemo() // Constructor { cout << "This is the DeriDemo constructor.\n"; } virtual ~DeriDemo() // Destructor { cout << "This is the DeriDemo destructor.\n"; } }; int main() { cout << "We will now create a DeriDemo obj ect.\n"; shared_ptr<DeriDemo> d = make_shared<DeriDemo>(); cout << "The program is now going to,end.\n"; return 0; }程序输出结果:
We will now create a DeriDemo obj ect.
This is the BaseDemo constructor.
This is the DeriDemo constructor.
The program is now going to,end.
This is the DeriDemo destructor.
This is the BaseDemo destructor.
所有教程
- socket
- Python基础教程
- C#教程
- MySQL函数
- MySQL
- C语言入门
- C语言专题
- C语言编译器
- C语言编程实例
- GCC编译器
- 数据结构
- C语言项目案例
- C++教程
- OpenCV
- Qt教程
- Unity 3D教程
- UE4
- STL
- Redis
- Android教程
- JavaScript
- PHP
- Mybatis
- Spring Cloud
- Maven
- vi命令
- Spring Boot
- Spring MVC
- Hibernate
- Linux
- Linux命令
- Shell脚本
- Java教程
- 设计模式
- Spring
- Servlet
- Struts2
- Java Swing
- JSP教程
- CSS教程
- TensorFlow
- 区块链
- Go语言教程
- Docker
- 编程笔记
- 资源下载
- 关于我们
- 汇编语言
- 大数据
- 云计算
- VIP视频