1关于const_iterator
当我们对const_iterator解引用时,可以得到一个指向const对象的引用,同任何常量一样,该对象不可重写。
例子:vector<int>::const_iterator iter=text.begin();
*iter=9;//这里是错误的,该迭代器指向的对象为const对象,不可更改。
2 声明一个const类型的iterator
vector<int> num(10);
const vector<int>::iterator iter=num.begin();
iter++; //error,can not chang the value of iter
*iter=10; //ok can change its underlying element
3.指向const对象的指针。
const char * cptr;
表明cptr指向的是一个const对象,不可随意更改。类似上面的const_iterator
4.const指针。
int errNumb=0;
int * const curErr=&errNumb;
表明curErr不可再指向其他地址了。
5指针与typedef
typedef string *pstring;
const pstring cstr;
一旦指针域typedef结合,千万别简单的认为文本扩展了。
正确分析:cstr是一个const pstring类型。在第一句中pstring为指向string对象的指针,经过const之后
意思是将cstr声明为指向string对象的const指针。
下面是关于其等价表达式:
----string *const cstr;
--typedef string *pstring;
pstring const cstr;