构造函数初始化列表
详细内容可以看《Effective C++》的条款4
对非内置类型成员变量,推荐使用类构造函数的初始化列表,但有时必须用带有初始化列表的构造函数:
- 没有默认构造函数的成员类对象
- const成员或引用类型的成员
构造函数初始值列表只能说明用于初始化成员的值,而不限定初始化的具体执行顺序,成员的初始化顺序与它们在类定义中的出现顺序一致。
构造函数的执行可以分成两个阶段,初始化阶段和计算阶段,初始化阶段先于计算阶段。
为什么使用初始化列表:
初始化类的成员有两种方式,一是使用初始化列表,二是在构造函数体内进行赋值操作。使用初始化列表主要是基于性能问题,对于内置类型,如int, float等,使用初始化类表和在构造函数体内初始化差别不是很大,但是对于类类型来说,最好使用初始化列表,使用初始化列表少了一次调用默认构造函数的过程,这对于数据密集型的类来说,是非常高效的。
原始的做法:
首先调用默认构造设初值,然后再赋值,默认构造所做的一切因此浪费,成员初始化列表避免了这一问题。
代码示例:
struct Test1
{
Test1() // 无参构造函数
{
cout << "Construct Test1" << endl ;
}
Test1(const Test1& t1) // 拷贝构造函数
{
cout << "Copy constructor for Test1" << endl ;
this->a = t1.a ;
}
Test1& operator = (const Test1& t1) // 赋值运算符
{
cout << "assignment for Test1" << endl ;
this->a = t1.a ;
return *this;
}
int a ;
};
struct Test2
{
Test1 test1 ;
Test2(Test1 &t1)
{
test1 = t1 ;
}
};
Test1 t1 ;
Test2 t2(t1) ;
输出:
struct Test2改为:
struct Test2
{
Test1 test1 ;
Test2(Test1 &t1):test1(t1){}
}