判断指针是否为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(它是值类型),即使所有字段都是指针:
立即学习“go语言免费学习笔记(深入)”;
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判断规范与错误避免的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1428870.html
微信扫一扫
支付宝扫一扫