继承中的构造和析构顺序

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;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值