首页 > 代码库 > C++基础知识---static const成员变量的初始化
C++基础知识---static const成员变量的初始化
为了将常量的作用域限制于class内,你必须让让成为class的一个成员;而为确保此常量之多只有一份实体,你必须让让成为一个static成员:
Class Gameplayer
{
Private:
Staticconst int Number = 5; //常量声明式
Intscores[Number]; //使用该常量
};
然而你所看到的是Number的声明式而非定义式。通常C++要求你对你所使用的任何东西提供一个定义式,但如果他是个class专属常量又是static且为整数类型,则需特殊处理。只要不取他们的地址,你可以声明并使用他们而无须提供定义式。但如果你取某个class专属常量的地址,或纵使你不取其地址而你的编译器却坚持要看到一个定义式,你就必须另外提供定义式如下:
Const int Gameplayer::Number; //Number的定义
请把这个式子放进一个实现问价而非头文件。由于class常量已在声明时获得初值,因此定义时不可以再设初值。
对于const关键字在STL迭代器中的使用:
STL迭代器系以指针为根据塑模出来,所以迭代器的作用就像个T*指针。声明迭代器为const就像声明指针为const一样(即声明一个T* const指针),表示这个迭代器不得指向不同的东西,但它所指的东西是可以改变的。如果你希望迭代器所指的东西不可被改动(既希望STL模拟一个const T*指针),你需要的是const_iterator;
Std::vector<int> vec;
Const vector<int>::iterator iter =vec.begin(); //iter的作用像是T* const
*iter = 10; //可以
++iter;// 不可以
Vector<int>::const_iterator citer =vec.begin();
*citer = 10; //错误
++citer;// 可以
Cost成员函数
将const作用域成员函数的目的,是为了确认该成员函数可作用于const对象身上。
C++有着十分固定的“成员初始化次序”。次序总是相同:base classes更早于其derived classes被初始化,而class的成员变量总是以其声明次序被初始化。即使他们的成员初值列中以不同的次序出现,也不会有任何影响。当你在成员初值列中条列各个成员时,最好总是以其声明次序为次序。
构造函数最好使用成员初值列,而不要在构造函数本体内使用赋值操作。初值列列出的成员变量,其排序次序应该和它们在class中的声明次序相同。
什么时候empty class(空类)不再是个empty class呢?当C++处理过它之后。如果你自己没声明,编译器就会为它声明(编译器版本的)一个copy 构造函数、一个copy assignment操作符和一个析构函数。此外如果你没有声明任何构造函数,编译器也会为你声明一个default构造函数。所有这些函数都是public且inline。同时只有当这些函数被需要,他们才会被编译创建出来。如果一旦用户自定义了任何构造函数,编译器就不会合成一个default 构造函数
如果你打算在一个“内含reference成员”的class内支持赋值操作,你必须自己定义copy assignment操作符。面对内含const成员的classes,编译器也是不赋值,也需要自定义copy assignment.如果某个base classes将copy assignment操作符声明为privaete,编译器将拒绝为其derived class生成一个copy assignment操作符。
所以还是自己定义这些函数比较靠谱,如果不想使用编译器自动生成的函数,就应该明确拒绝
赋值(assignment)操作符返回一个reference to *this
C++基础知识---static const成员变量的初始化