类的成员变量的初始化顺序只与变量在类中的声明顺序有关,与在构造函数中的初始化列表顺序无关。
- 注意:是与声明顺序有关。
#include<iostream>
using namespace std;
class A {
public:
//我们原意是先初始化b,再用b初始化a。
//但结果可以看出,类的成员变量的初始化顺序与声明顺序有关,先初始化的a,再初始化的b。
A(int val):b(val),a(b){}
public:
int a;
int b;
};
int main(int argc, char* argv[]) {
A A1(10);
cout << A1.a << endl;
cout << A1.b << endl;
getchar();
return 0;
}
静态成员变量先于实例变量,父类成员变量先于子类成员变量,父类构造函数先于子类构造函数。
从全局看,变量的初始化顺序如下(重要!!!):
- 基类的静态变量或全局变量。
- 派生类的静态变量或全局变量。
- 基类的成员变量。
- 派生类的成员变量。
扩展:初始化列表和构造函数初始化的区别
- 初始化列表一般为:
A1(int a):a(a){}
- 构造函数初始化一般为:
A1(int a) {
this->a = a;
}
很多场合必须使用带有初始化列表的构造函数。例如,const成员或引用类型的成员,因为const对象或者引用类型只能初始化,不能对他们赋值。(重要!!!)
正确
class A1 {
A1(int a,int val):a(a),b(val) {}
private:
const int a;
int& b;
};
- 错误
class A1 {
A1(int a,int val) {
this->a=a;
b=val;
}
private:
const int a;
int& b;
};