1. 指向const对象的指针
如:const double *cptr;
这里的cptr 是一个指向double类型const对象的指针,const限定了cptr指针所指向的对象类型,而并非cptr本身。通俗点说,cptr本身不是const。
可对cptr进行的操作: 重新赋值,使其指向另一个const对象
不能对cptr进行的操作: 通过cptr修改其对象的值
*cptr = 42; // error: *cptr might be const
下面几种情况需注意:
- 把一个const对象的地址赋给 非const对象的指针 也会导致编译时的错误。
const double pi = 3.14;
doule *ptr = π // error: ptr is a plain pointer
const double *cptr = π // ok: cptr is a point to const
- 不能使用 void* 指针保存 const 对象的地址, 而必须使用 const void* 类型的指针
const int n = 42;
void *pv = &n; // error: pv is not const
const void *cpv = &n; // ok: cpv is const
- 允许把 非const对象的地址 赋给指向const对象的指针
double dval = 3.14;
const double cptr = &dval; // ok , but can't change dval through cptr
2. const指针
int n = 0;
int *const cur = &n; // cur is a constant pointer
这里的cur是指向int型对象的const指针
可对cur进行的操作: 通过cur修改其对象的值
不能对cur进行的操作: 重新赋值,使其指向另一个const对象
cur = cur; // error: cur is const
*cur = 1; // ok: reset value of the object
3. 指向const 对象的const 指针
const double pi = 3.14159;
const double *const pi_ptr = π
从右向左阅读声明语句:“pi_ptr是一个指针,指向 double 类型的 const 对象”
不能对cur进行的操作: 通过pi_ptr修改其对象的值
不能对cur进行的操作: 重新赋值,使其指向另一个const对象
4. 指针和 typedef
typedef string *pstring;
const pstring cstr;
问 cstr 是什么类型 ?
……………………………………………………………………………………………………………………………
……………………………………………………………………………………………………………………………
A const string *cstr 即指向string 类型 const 对象的指针
B string *const cstr 即指向string类型对象的 const 指针
……………………………………………………………………………………………………………………………
……………………………………………………………………………………………………………………………
你选择了 A 还是 B ?
……………………………………………………………………………………………………………………………
……………………………………………………………………………………………………………………………
……………………………………………………………………………………………………………………………
解析: cstr 是 指向 string 类型对象的 const 指针 。用 typedef 写 const 类型定义时,const 限定符加在类型名前面容易引起对定义的真正类型的误解。认为是 const string *cstr 原因在于 把typedef 当做文本扩展了。声明 const pstring 时, const 修饰的是pstring 的类型, 是一个指针。
下面三种写法意思一样:
string s;
typedef string *pstring;
const pstring cstr1 = &s; // ①
pstring const cstr1 = &s; // ②
string *const cstr1 = &s; // ③