const位置决定指针语义:const在左边(如const int)表示指向const的指针,不可修改所指对象;在指针名右边(如int* const)表示const指针,不可修改指针本身;两者兼具则均不可变。

const 在 * 左边还是右边决定语义
判断一个指针声明是「指向 const 的指针」还是「const 指针」,只看 const 直接修饰谁:
— const 紧挨 * 左边(如 const int*),表示「指向 const int 的指针」,即不能通过它修改所指对象;
— const 紧挨指针名右边(如 int* const),表示「const 指针」,即指针本身不可再赋值指向别处。
常见易错声明与对应错误行为
这些写法看着像,但语义完全不同,编译器报错位置也不同:
-
const int* p1 = &x;→ 允许p1 = &y;,但禁止*p1 = 5;(报错:assignment of read-only location) -
int* const p2 = &x;→ 禁止p2 = &y;(报错:assignment of read-only variable 'p2'),但允许*p2 = 5; -
const int* const p3 = &x;→ 两者都禁止,p3和*p3都不可变
从右往左读口诀真有用
把声明当英语读,从右往左解析更可靠。例如:
— int* const p → “p is const pointer to int” → p 是 int 的 const 指针
— const int* p → “p is pointer to const int” → p 是指向 const int 的指针
— const int* const p → “p is const pointer to const int”
这个顺序和 C++ 声明语法一致(类型修饰符从右向左绑定),比死记“左定值、右定址”更少歧义。
立即学习“C++免费学习笔记(深入)”;
函数参数中 const 指针的典型用法
实际编码里,const 指针多用于表达意图和避免意外修改:
- 传入只读数据时用
const T*:如void print(const char* s),确保函数内不改s所指字符串 - 传入固定地址且不允许重绑定时用
T* const:少见,但可用于封装类内部缓存指针(如Buffer* const m_buf) - 返回局部 const 指针要小心:如
const int* get_ptr() { return &local; }是悬垂指针,const不解决生命周期问题
真正容易被忽略的是:const 修饰的是「通过该指针访问时的行为约束」,不是内存本身的只读性;底层内存仍可能被其他非 const 途径修改(比如同时存在 int* q = &x; 和 const int* p = &x;)。









