指针常量
指针常量,用指针修饰的常量,它的本质是一个常量
int a = 111, b = 222;
int * const p = &a;
printf("%p\n",p);
printf("%d\n",*p);
*p = 333;
printf("%d\n",*p);
p = &b; //报错,p的值不能更改,[Error] assignment of read-only variable 'p'
结果
000000000024FE3C
111
333
这个常量的类型是 int *。所以p的值是常量,也就是说p所指向的地址是不能更改的,但是地址上的值可以更改。
常量指针
指向常量的指针,它本身是一个指针,这个指针指向一个常量。
int a = 111, b = 222;
const int * p = &a;
printf("%d\n",*p);
//*p = 333;//报错,[Error] assignment of read-only location '*p'
p = &b;
printf("%d\n",*p);
a = 333;
printf("%d\n",a);
结果:
111
222
333
指针p的值可以更改,也就是说p指向的地址可以更改,但是地址上的值不能更改(不能通过*p来更改)。
常量指正经常用在函数形参中,用于保护数据不受更改:
//函数原型
int sum(const int * list);//传入的是个常量指针,list的数据只能被读取,不能被更改
适用于constzhi指针的规则:
- 一个const变量的地址只能分配给一个指向const类型的指针。
- 一个指向const类型的指针的值只能被赋给另一个const类型的指针。
非cosnt指针的地址和值可以赋给const指针
cosnt指针的地址和值不能赋给非const指针
cosnt int ci = 0, *ci_ptr;
int nci = 0,*nci_ptr;
//const指针赋给const,非const赋给非const,正确
ci_ptr = &ci;
nci_ptr = &nci;
//非const赋给const,正确
ci_ptr = &ci;
ci_ptr = nci_ptr;
//将cosnt赋给非const,不正确
nci_ptr = &ci;
nci_ptr = ci_ptr;
在函数中更能体现其作用:
给定一个函数:
void test(const int *p);
它接收一个int的地址,并且不能更改p指向的数据。
test(ci_ptr);
test(nci_ptr);
它可以传入const指针或者普通指针。反之不然,假设
void test2(int *p);
则下面的调用是不允许的,因为它会取消一个const地址的const保护:
test(ci_ptr);