C++类的构造函数可以包含一个构造函数初始化列表,如下
class B
{
public:
B(int n):num(n){}
private:
int num;
};
(1)构造函数分两个阶段执行,首先是初始化阶段,然后是普通的计算阶段,计算阶段由构造函数函数体中的所有语句组成。不管成员是否在构造函数初始化列表中显示初始化,类类型的数据成员总是在初始化阶段。对于类类型数据成员,如果没有在初始化列表中显示指定初始化,则编译器会隐式的调用该类类型数据成员的默认构造函数。
#include <iostream>
using namespace std;
class A
{
public:
A(){
cout<<"Constructor A"<<endl;
}
};
class B
{
public:
B(){
}
private:
A a;
};
int main()
{
B b;
return 0;
}
运行结果如下:
[root@oneeight ~]# ./a.out
Constructor A
因为编译器会隐式的调用类数据成员的默认构造函数,所以类数据成员必须要提供默认构造函数。
(2)一些成员必须在构造函数初始化列表中进行初始化,对于这样的成员,在构造函数函数体中对它们赋值不起作用没有默认构造函数的类类型的成员、const或引用类型的成员。
#include <iostream>
using namespace std;
class A
{
public:
A(int num1, int &num2):num1(num1), num2(num2){
}
private:
const int num1;
int &num2;
};
int main()
{
int num1=1;
int num2=2;
A a(num1, num2);
return 0;
}
对于const数据成员或者引用类型数据成员,可以进行初始化,但是不能不能赋值,所以必须在初始化式中完成初始化。
(3)成员初始化的顺序是定义成员的顺序,与在初始化列表中指定的顺序无关。
#include <iostream>
using namespace std;
class B
{
public:
B(int num){
cout<<"Constructor B "<<num<<endl;
}
};
class A
{
public:
A(int n1, int n2, int n3):b2(n1),b1(n2),b3(n3){
}
private:
B b1;
B b2;
B b3;
};
int main()
{
int num1=1;
int num2=2;
int num3=3;
A a(num1, num2, num3);
return 0;
}
输出如下:
[root@oneeight ~]# ./a.out
Constructor B 2
Constructor B 1
Constructor B 3