类中const, static, reference成员的初始化

时间:2021-06-20 20:02:40
1. 初始化一个引用变量必须在定义的时候。

而所有的运算符操作都被视为赋值而不是初始化,所以引用参数的初始化必须在初始化列表中进行。

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 成员赋值。 同样的道理,如果要初始化一个引用类型的成员变量,也不能在构造函数体内赋值,而只能在构造函数的初始化列表中进行初始化。