C++ 初始化列表
C++中提供了初始化列表对成员变量进行初始化。
语法规则:class_name::class_name()
m1(v1),m2(v2,v3),m3(v3)
{
.......
}
注意:
成员的初始化顺序,与成员的声明顺序相同。
成员的初始化顺序与初始化列表的位置无关。
初始化列表比构造函数先执行。
测试代码:
#include <stdio.h> class val { private: int i; public: val(int val) { i = val; printf("i = %d\n",i); } }; class Test { private: const int Ci=10; val m1; val m2; public: Test():m2(2),m1(1) { //Ci = 1; printf("Test::Test()\n"); } int get_Ci() { return Ci; } }; int main(int argc, char *argv[]) { Test Ci; printf("Ci = %d\n",Ci.get_Ci()); return 0; }
运行结果:
i = 1 i = 2 Test::Test() Ci = 10
类中的const成员
类中个const成员变量会被分配空间,(所分配空间的位置取决于对象在哪个位置被声明。)
类中的const 成员的实质是一个只读变量,可以通过指针修改其值。
类中个const 可以使用初始化列表指定初始值,也可以在定义的时候进行初始化。、
注意:编译器无法得到const成员的初始值,因此在类中声明的const 只读变量无法进入符号表成为一个真正意义上的常量。
测试代码:
#include <stdio.h> class val { private: int i; public: val(int val) { i = val; printf("i = %d\n",i); } }; class Test { private: const int Ci; val m1; val m2; public: Test():m2(2),m1(1),Ci(100) { //Ci = 1; printf("Test::Test()\n"); } int get_Ci() { return Ci; } void change_Ci(int CI) { int *p = const_cast<int *>(&Ci);//delete only read *p = CI; } }; int main(int argc, char *argv[]) { Test Ci; printf("Ci = %d\n",Ci.get_Ci()); Ci.change_Ci(1000); printf("Ci = %d\n",Ci.get_Ci()); return 0; }
上面代码通过 const_cast<Type *>(&val);关键字去掉了Ci的只读属性。
然后通过*p = CI; 修改Ci的值
运行结果:
i = 1 i = 2 Test::Test() Ci = 100 Ci = 1000