而所有的运算符操作都被视为赋值而不是初始化,所以引用参数的初始化必须在初始化列表中进行。
class Test{
public:
Test(int val) : ref_(val){}
~Test() {}
private:
int & ref_;};
int main(){
Test t(1);
return 0;
}
也许你不会碰见任何问题,但这里我们会发现val是一个形式参数,但构造函数执行完后它会自动释放,所以更好的方式是:
class Test{
public:
Test(int &val) : ref_(val){}
~Test() {}
private:
int & ref_;
};
int main(){int a=1;
Test t(a);
return 0;
}
2. 初始化const refference成员则可以直接赋值
const int & ref2 = 3;
那么一个const int类型的temporary数会被产生,这个数就来对它进行赋值。
3. 初始化 static const 成员,也就是全局的静态常量。比如:
class Test{
public:
static const int MASK;// 申明int 型的MASK 常量
};
const int Test::MASK = 0xFFFF;// 定义Test::MASK 常量,注意这里不需要static 关键字
4. 初始化const成员 如:
class Test{
public:
const int MY_MASK;
};
这种情况下,要在实例文件中像初始化 static const 常量一样,对其进行初始化是行不通的。
const int Test::MY_MASK = 0xFF; // 这样会报重定义错误
况且,就算编译能通过,也不能达到我们要求的“每个对象自己的常量”的要求。
正确的初始化是通过构造函数的初始化列表来进行,如:
class Test {
public:
const int MY_MASK;
Test() : MY_MASK(0xff) {}
};
如果不是在初始化列表中对 const 常量进行初始化,而是在构造函数中对其赋值的话,是不能成功的。很简单的道理:不能给 const 成员赋值。 同样的道理,如果要初始化一个引用类型的成员变量,也不能在构造函数体内赋值,而只能在构造函数的初始化列表中进行初始化。