注意:类成员初始化的顺序跟成员在类内声明的顺序一致。如果使用多继承,基类被初始化的顺序和它们被派生类继承的顺序一致。类成员初化在构造函数成员初始化列表中的顺序会被忽略。
我们用一个例子来说明。如下:
#include <iostream>
using namespace std;
public:
B()
{
cout<<"B construct"<<endl;
}
public:
wacko():b(),a(){}
private:
A a;
B b;
wacko w1;
A construct
B construct
先初始化a,再初始化b。
因此不管类成员在初始化列表中的顺序如何,去初始化的顺序是在类中声明的顺序,所以我们在代码书写时应注意[初始化列表中成员列出的顺序和它们在类中声明的顺序相同],这样代码的可读性与可维护性就会增强,不容易让人误解。
我们用一个例子来说明。如下:
#include <iostream>
using namespace std;
class A{
public:
A()
{
cout<<"A construct"<<endl;
}
};
class B{
public:
B()
{
cout<<"B construct"<<endl;
}
};
class wacko {
public:
wacko():b(),a(){}
private:
A a;
B b;
};
int main(int argc,char * argv[]) {
wacko w1;
return 0;
}
在上面的代码中,wacko():b(),a(){}初始化列表的顺序是先初始化b再初始化a,但是上面的代码运行结果是
A construct
B construct
先初始化a,再初始化b。
因此不管类成员在初始化列表中的顺序如何,去初始化的顺序是在类中声明的顺序,所以我们在代码书写时应注意[初始化列表中成员列出的顺序和它们在类中声明的顺序相同],这样代码的可读性与可维护性就会增强,不容易让人误解。