最近看C++11新特性的时候手闲尝试了一下继承构造的内容,其中发现了很奇怪的调用顺序:
父类Base在有无参数和有参数的构造函数的情况下,子类使用using Base::Base;可以继承父类所有的构造函数,没毛病。
但子类如果后续也分别写了有参数和无参数的构造函数时就出现了如下情况
如下代码:
#include <iostream>
using namespace std;
class Base {
public:
int value1=0;
int value2=0;
Base() {
value1 = 1;
}
Base(int value) : Base() {
value2 = 2;
}
};
class Next : Base {
public:
using Base::Base;
int value3 = 0;
int value4 = 0;
Next() {
value3 = 3;
}
Next(int value) {
value4 = 4;
}
void show() {
cout << this->value1 << endl;
cout << this->value2 << endl;
cout << this->value3 << endl;
cout << this->value4 << endl;
}
};
int main(int argc, char** argv)
{
Next N;
Next N2(3);
cout << "N:" << endl;
N.show();
cout << "N2(3):" << endl;
N2.show();
cout << "finish" << endl;
}
结果:
N:
1
0
3
0
N2(3):
1
0
0
4
finish
按我最初的的想象 :
对象N创建时,(1)首先调用了Base的无参构造函数,(2)后调用Next的无参构造函数。
对象N2创建时,(1)首先调用Base的Base的无参构造函数,(2)后调用Base的有参构造函数,(3)最后再调用Next的有参构造函数
然而N2的实际情况却并没有调用Base的有参构造函数。
因此在使用C++11新的继承构造语句的时候要注意这点。