Go中error是接口类型,nil表示无错误;直接用err != nil判断最安全,避免转为interface{}后判空失效,需用errors.Is/As区分错误类型,自定义error时确保Error()不panic。

Go 中的 error 是接口类型,nil 表示“无错误”,但判断它是否为 nil 看似简单,实则容易踩坑。关键不是“怎么写 if”,而是“什么时候会误判”。
只要 error 变量是函数原生返回的(比如 os.ReadFile、json.Unmarshal),直接用 if err != nil 就足够可靠:
nil,失败时返回非 nil error”的约定nil 是接口的零值,不是指针或结构体的 nil,无需额外反射或类型转换if err == nil { ... } else { ... } 嵌套过深,推荐提前 return:content, err := os.ReadFile("config.json")
if err != nil {
log.Fatal("读取配置失败:", err)
}
// 后续逻辑直接写在这里,不用 else 包裹
这是最隐蔽的 nil 判断失效场景:
var e interface{} = err,再判断 e == nil,结果可能不符合预期interface{} 的 nil 要求底层类型和值都为 nil;而一个 *MyError 类型的 error 值即使为 nil,装进 interface{} 后也不是接口意义上的 nil
error 转成 interface{} 再做 == nil 判断当你要判断是不是某个特定错误(比如文件不存在、超时),别用字符串匹配或强制类型断言:
errors.Is(err, os.ErrNotExist) —— 判断是否是同一类错误(支持包装链)var pathErr *os.PathError; if errors.As(err, &pathErr) { ... } —— 安全提取底层错误详情,比如 pathErr.Path
nil 边界情况,比手写 err.(*os.PathError) 更健壮如果你实现了 error 接口,务必保证 Error() 返回字符串时不会触发 panic:
nil 指针,调用前要判空:if e.detail != nil { return e.detail.String() }
fmt.Printf("%v", err) 时程序崩溃,表面看像是 “nil error 导致 panic”,其实是自定义逻辑缺陷if err != nil { _ = err.Error() } 快速暴露问题基本上就这些。nil error 判断本身不复杂,但容易忽略类型转换和接口包装带来的语义变化。坚持原生判空、慎用 interface{}、善用 errors 包工具,就能避开大部分陷阱。
以上就是如何处理Go中出现的nil error问题_Go nil error判断技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号