您的位置:首页 > 编程语言 > C语言/C++

C++基础知识---static const初始化成员变量

2015-11-07 11:02 337 查看
为了限制常数的范围class中。你必须要做出成为class成员;而要确保这是丝毫不亚于有一个恒定的实体。你必须要做出成为static员:

Class Gameplayer

{

Private:

Staticconst int Number = 5; //常量声明式

Intscores[Number]; //使用该常量

}。

然而你所示是Number的声明式而非定义式。通常C++要求你对你所使用的不论什么东西提供一个定义式,但假设他是个class专属常量又是static且为整数类型,则需特殊处理。仅仅要不取他们的地址,你能够声明并使用他们而无须提供定义式。但假设你取某个class专属常量的地址,或纵使你不取其地址而你的编译器却坚持要看到一个定义式,你就必须另外提供定义式例如以下:

Const int Gameplayer::Number; //Number的定义

请把这个式子放进一个实现问价而非头文件。

因为class常量已在声明时获得初值。因此定义时不能够再设初值。

对于constkeyword在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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: