目录
1.分清赋值与初始化
对于赋值,看如下class, 这里对象的成员变量name、address都不是被初始化的,而是被赋值的。
具体过程是:首先调用缺省的构造函数为name、address设置初值,然后在调用赋值操作符函数进行赋值的。
class temp{
public:
temp(string& m_name, string& m_address){
name = m_name;
address = m_address;
num = 0;
}
private:
string name;
string address;
int num;
};
对于初始化,再看如下class,c++规定对象的成员变量的初始化动作发生在进入构造函数本体之前,发生在这些成员的缺省构造函数自动调用之时(这个要比进入temp构造函数内部的时间要早)。
于是成员初始化列表应运而生,此时name、address均都是调用相应的copy构造函数进行初始化。
class temp{
public:
temp(string& m_name, string& m_address):name(m_name),address(m_address),num(0){
}
private:
string name;
string address;
int num;
};
总结:对于赋值,是先执行缺省构造函数,在执行赋值操作符函数;对于初始化,是只执行copy构造函数。对于大多数类型而言,使用初始化列表进行的初始化效率更高。这里还要提的是对于num这种内置类型无论是赋值还是列表初始化效率相同,两种方式皆可,只是我们不要忘记初始化它就行。
2.成员初始化列表必用的几种形式
- 子类继承父类,用于初始化父类
- 在类中如果有成员类对象
- 在类中如果有const成员
- 在类中如果引用成员
3.成员初始化次序
成员初始化的顺序按照声明的顺序,与初始化列表的顺序无关。比如上面的例子中,先初始化name,然后在初始化address。如果初始化列表先写address,在写name,也亦如此。
参考:《Effective C++》