继承中的构造和析构顺序
作者:互联网
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