贝利信息

Golang指针可以做哪些操作_指针使用限制解析

日期:2026-01-19 00:00 / 作者:P粉602998670
Go指针禁止对不可寻址值取地址(如字面量、表达式结果、map元素、函数调用返回值),解引用nil指针必panic,传指针仅在需修改原值或值过大时必要。

Go 指针能做的操作很明确:取地址、解引用、传参、作为方法接收者、访问结构体字段(语法糖支持),但**不能做指针算术、不能对不可寻址值取地址、不能隐式转换类型**——这些不是“功能缺失”,而是 Go 编译器主动封堵的危险路径。

哪些值 &v 会编译报错?

Go 编译器禁止对“不可寻址”的值取地址,防止语义混乱和悬垂风险。常见报错场景:

✅ 正确做法:先赋给局部变量再取地址

val := myMap["key"]
val.Field = 100
myMap["key"] = val

为什么 *p 有时 panic,有时却能直接写 p.Name

本质是 nil 检查时机不同:*p 是显式解引用,只要 p == nil 就 panic;而 p.Name 是语法糖(等价于 (*p).Name),同样会 panic —— 它们不是“安全”与“不安全”的区别,而是同一种检查。

传指针 vs 传值:什么时候真该用 *T

核心就两条:要改原值,或值太大(通常 > 128 字节)。别被“结构体都要用指针接收者”带偏。

容易被忽略的“逻辑野指针”场景

Go 不会出现 C 那种真正的野指针(栈地址被复用),但以下情况会导致“指针还活着,但指向的数据已失效或不该被改”:

真正难防的不是 panic,而是那种“程序没崩,但行为不对”的共享误用——它不会报错,只会在某个并发时刻悄悄改掉你没意识到的字段。