const *p & *const p
看const离哪个近
const *p即const (*p),p指向地址的内容不可改变,但指向的地址可以改变;
*const p即 *(const p),const修饰的是地址,故p指向的地址不可改变,但是p指向地址的内容可以改变。
const总结
常变量: const 类型说明符 变量名
常引用: const 类型说明符 &引用名
常对象: 类名 const 对象名
常成员函数: 类名::fun(形参) const
常数组: 类型说明符 const 数组名[大小]
常指针: const 类型说明符* 指针名 ,类型说明符* const 指针名
首先提示的是:在常变量(const 类型说明符 变量名)、常引用(const 类型说明符 &引用名)、常对象(类名 const 对象名)、 常数组(类型说明符 const 数组名[大小]), const与 “类型说明符”或“类名”(其实类名是一种自定义的类型说明符) 的位置可以互换。如:
const int a=5; 与 int const a=5; 等同
类名 const 对象名 与 const 类名 对象名 等同
那么怎么区分呢?
把一个声明从右向左读。
char * const cp; ( * 读成 pointer to) cp is a const pointer to char;
const char * p; p is a pointer to constchar;
char const * GetNumber()const
第一个const表明函数返回值如果不为空,那么其指向是不允许修改的,但其指向的值是可以修改的,指针指向的对象是常量。
第二个const这种用法常用在类的成员函数声明和实现中,表示这个类的实现中,不能修改类的数据成员。
一些易混淆的声明
const char *p; //p是const,不可修改,p可变
char const * p;// p是const,不可修改,p可变
(因为没有constp运算,因此const修饰的还是前面的char)
const (char ) p;//p是const,p可变
char const p; //p是const,p可变
const char const p; //p和p都是const
(char) const p;//p是const,p可变
char const p;// p是const,*p可变
const char p或者char constp; //涉及两个指针p和 p。由于const修饰char ,对指针p没有任何限定,而指针p指向的内容不可改变,p本身可变
char const p; //涉及两个指针p和 p。由于const修饰前面的char,也就是对p所指向的内容p进行了限定,就是p不能修改。而对p来说,不能通过"*p=…"来进行另外赋值
啊啊啊啊!头疼!先记下来,防止以后用得着吧!