判断指针是否为nil需明确类型:Go中指针、切片、map等类型的零值为nil,可安全使用== nil比较;但结构体本身非指针不能与nil比较,且interface{}包含类型信息时即使值为nil也不等于nil。1. 指针变量未初始化时为nil,可直接比较;2. 结构体字段指针需单独判空;3. make初始化的slice、map非nil,而var声明的为nil;4. interface{}判nil需同时考虑类型和值。核心是理解nil的类型相关性及各类型的零值行为。

在 Go 中,判断指针是否为 nil 很简单:直接用 == nil 即可。但真正容易出错的,不是语法本身,而是对“什么算 nil”理解偏差、类型混淆、以及未初始化变量的误判。
指针变量本身的 nil 判断是安全且标准的
Go 中所有指针类型的零值都是 nil,包括自定义结构体指针、切片指针、map 指针等。只要变量声明为指针类型(如 *string、*MyStruct),未赋值时就是 nil,可直接比较:
-
var p *int; if p == nil { ... }✅ 安全有效 -
if ptr != nil { fmt.Println(*ptr) }✅ 典型防护性解引用
别把非指针类型当成指针来判 nil
常见错误是混淆“值为 nil 的指针”和“本身能为 nil 的引用类型”。例如:
-
slice、map、func、channel、interface{}本身可以是nil,但它们不是指针类型 —— 判 nil 合法,但逻辑上不是“指针为空” -
var s []int; if s == nil { ... }✅ 正确(slice 是引用类型,零值为 nil) -
var i interface{}; if i == nil { ... }✅ 合法,但要注意:若i = (*int)(nil),此时i != nil(因 interface 包含类型和值,非空类型 + nil 值 ≠ interface nil)
结构体字段指针需单独判断,不能依赖结构体整体
结构体变量本身永远不会是 nil(它是值类型),即使所有字段都是指针:
Zapier推出的Agents智能体,集成7000+应用程序
103 立即学习“”;
type User struct{ Name *string }-
u := User{}; if u == nil { ... }❌ 编译报错:User 不支持与 nil 比较 - 正确做法:
if u.Name != nil { fmt.Println(*u.Name) }✅
避免“”导致的误判:new、&、make 要分清
初始化方式影响初始值是否为 nil:
-
p := new(int)→ 返回*int,指向新分配的零值内存,p != nil -
var p *int→ 零值,p == nil -
s := make([]int, 0)→ slice 非 nil(有底层数组),但长度为 0 -
var s []int→ slice 为 nil,len(s)和cap(s)都为 0,但s == nil成立
基本上就这些。记住核心:Go 的 nil 是类型相关的零值,只对指针、切片、map、chan、func、interface 这六类有效;判断指针是否为空,永远用 == nil,但务必确认你操作的真是指针类型。
以上就是Golang如何判断一个指针是否为空_Golang nil判断规范与错误避免的详细内容,更多请关注php中文网其它相关文章!
微信扫一扫打赏
支付宝扫一扫打赏
