其他分享
首页 > 其他分享> > 继承中的构造和析构顺序

继承中的构造和析构顺序

作者:互联网

8.1 子类创建对象时,先调用父类的构造,然后调用自身构造
8.2 析构顺序与构造顺序相反
8.3 子类是不会继承父类的构造函数和析构函数
8.4 补充内容,如果父类中没有合适默认构造,那么子类可以利用初始化列表的方式显示的调用父类的其他构造

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<string>
using namespace std;

class Modulator {
public:
	Modulator() {
		cout << "Modulator默认构造函数调用" << endl;
	}
	~Modulator() {
		cout << "Modulator的析构函数调用" << endl;
	}
};

class Demodulator:public Modulator {
public:
	Demodulator() {
		cout << "Demodulator默认构造函数调用" << endl;
	}
	~Demodulator() {
		cout << "Demodulator的析构函数调用" << endl;
	}
};

void test01() {
	Demodulator dem;
}
int main(){
	test01();
	
	system("pause");
	return 0;
}

在这里插入图片描述

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<string>
using namespace std;

class Modulator {
public:
	Modulator(int a) {
		this->m_a = a;
		cout << "Modulator默认构造函数调用" << endl;
	}
	~Modulator() {
		cout << "Modulator的析构函数调用" << endl;
	}
	
	int m_a;
};

// 子类会继承父类的成员属性,成员函数
//但是 子类 不会继承 父类 构造函数 和 析构函数
//只有父类自己知道如果构造和析构自己的属性,而子类不知道

class Demodulator :public Modulator {
public:
	Demodulator(int a) :Modulator(a){ //利用初始化列表方式 显示调用 有参构造
		cout << "Demodulator默认构造函数调用" << endl;
	}
	~Demodulator() {
		cout << "Demodulator的析构函数调用" << endl;
	}
};

void test01() {
	Demodulator dem(26);
}
int main() {
	test01();

	system("pause");
	return 0;
}

标签:顺序,cout,Modulator,int,构造,include,和析构,public,Demodulator
来源: https://blog.csdn.net/Scarlett2025/article/details/120907461