今天在看项目代码时,发现竟然可以给有const修饰的指针赋值,按道理的话,const修饰的不是常量吗?常量应该是初始化之后就不能再修改才对。对于这个问题,我大致的研究了一下。
参考const 指针与指向const的指针 const的理解、const指针、指向const的指针
首先对于普通的const常量,必须在声明的时候初始化,否则会报错。
const int a = 100;
而对于const指针来说,根据const与*的相对位置,可以分成三种不同的情况:
-
const指针:const关健字在*的右边
-
指向const的指针:const关健字在*的左边
-
指针和内容都是不可变:*被两个const关键字夹在中间
const指针
int* const p=一个地址; //因为指针本身的值是不能被修改的所以它必须被初始化 *p = 100; //地址里的值可以被修改
const指针必须在声明时初始化,而且指针只能指向这一个地址,后续不能再指向其他地址。但是这个内存地址里的值可以被修改。
指向const的指针
指向const的指针有两种写法,但共同点是const关键字在*的左边。
const int* p; //推荐使用这种写法 int const* p; const int a =3; p = &a;
指向const的指针声明时可以不初始化,该指针可以修改指向的地址,但是它无权修改地址里的值。
是一种“自以为指向const对象的指针”:其实它可以指向const对象,也可以指向非const对象:
int deval=5; const int * pdeval; pdeval = &deval;这是允许的。
所以这句论断是错误的:指向const对象的指针所指的一定是const对象。(X)
指针和内容都是不可变的
const int * const p = 地址值 int const * const p = 地址值
由于既是const指针又是指向const的指针,因此指针p不仅不能修改指向的地址,而且不能修改地址处的值,因此必须在声明时初始化。