Bootstrap

C++构造函数的初始化列表

构造函数初始化列表

详细内容可以看《Effective C++》的条款4

对非内置类型成员变量,推荐使用类构造函数的初始化列表,但有时必须用带有初始化列表的构造函数:
  1. 没有默认构造函数的成员类对象
  2. 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){}
}

输出:

在这里插入图片描述

;