1)先从const int i说起。
使用const修饰的i我们称之为符号常量。即,i不能在其他地方被重新赋值了。注意:const int i与int const i是等价的,相同的,即const与int的位置无所谓。
2)const int *p(指向常量的指针,常量不可改变;指针指向的值不可变,但是指针可以指向其他量)值不变,地址可变
看例子:
int i1=30;
int i2=40;
const int *p=&i1;
p=&i2;
i2=80;
printf("%d",*p);
分析:p的值是可以被修改的,即它可以重新指向另一个地址。但是不能通过*p来修改i2的值。
首先,const修饰的是整个*p(注意,是*p而不是p),所以*p是常量,是不能被赋值的。虽然p所指的i2是变量而不是常量;
其次,p前并没有用const修饰,所以p是指针变量。能被赋值重新指向另一个内存地址。
3)int * const p(常指针,指针指向的地址不变,除非改变该地址的值)
int i1=30;
int i2=40;
int * const p=&i1;
//p=&i2;
i1=80;
printf("%d",*p);
分析:
此时p的值不能被赋值修改了,只能永远指向初始化时候的内存地址。相反,可用*p修改i1的值了。
所以:综上所述,
指针p因为有了const的修饰,所以为指针常量,即,指针p不能修改了。
整个*p前面没有const修饰,则*p为变量而不是常量,所以,可改变*p的值。
如果const修饰在*p前则不能改的是*p,而不是指p;
如果const是直接写在p前,则p不能改。
4)补充
const int i1=40;
int *p;
p=&i1;
----------------------------------------
const int i1=40;
const int *p;
p=&i1;
转http://blog.sina.com.cn/s/blog_6af956630100vpv2.html
上次中兴一道笔试题。当时是猜的,回来总结一下。
char * const p 与 char const * p 。
2)const int *p; p为指向字符变量的指针,地址可变,地址内容不变,从左往右读 "常量的指针"。
3)const int* const p (指针不能变,指的量也不能变)
4)*在const前表示指针为常量,只能初始化,初始化后就不能再指向别的地址,但是可以改变指针指向的变量的值。
const在*前面,表示指针指向的值为常量,但是指针可以指向不同的变量。
5)char const *p; 与 const char *p; 等价,只是个人的书写习惯,主要区别是const 和 * 位置的区别。
上面程序运行结果如下:
- p:6
- p1:-33686019
- p4:-33686019
- p2:6
- p3:5
- Press any key to continue
http://blog.youkuaiyun.com/clam_clam/article/details/6824275