Go 中 nil是类型明确的零值,需按类型语义安全处理:指针解引用前必判 nil;接口需双检 i == nil 或 reflect.ValueOf(i).IsNil();error 用 err != nil 判断;切片/map/channel 虽可传参但操作前需验证有效性。
Go 里 nil 不是万能的“空值占位符”,而是类型明确的零值。安全处理 nil 的核心不是回避它,而是理解它在不同类型的语义,并建立可落地的检查习惯。
对 *T 类型指针直接取值(*p)或调用方法时,若 p == nil,会立即 panic。这不是逻辑错误,而是运行时崩溃。
var u *User; u.Greet() 会挂掉var u *User; return u)interface{} 的零值是 nil,但 var u *User; var i interface{} = u 中,i 不为 nil(类型存在,值为 nil),直接 i == nil 判断失败。
error 是接口,其零值就是 nil。所以 err != nil 是 Go 错误处理的基石判断,但它本身不危险——只是普通比较。
err == os.ErrNotExist,兼容包装链nil 切片可 len()、cap()、range,但不能索引(s[0] panic);nil map 不能赋值(m["k"] = v panic);nil channel 不能收发( 阻塞或 panic)。
s == nil
staticcheck)自动捕获常见 nil 解引用场景基本上就这些。nil 不可怕,可怕的是假设它“安全”或“不存在”。养成声明即初始化、使用前必检查、返回前保非空的习惯,比任何技巧都管用。