go 函数错误处理模式有:使用 errors.new() 创建错误、包装底层错误、返回 nil 表示无错误。反模式包括:使用魔数或字符串表示错误、隐式处理错误、忽略错误、延迟退出模式。最佳实践案例:使用 errors.new() 创建并返回错误。反模式案例:忽略 os.open() 返回的错误。遵循最佳实践和避免反模式可编写出清晰、可维护、易于调试的代码。
Go 函数错误处理的模式与反模式
在 Go 中处理错误时,有许多方法可以实现。然而,并非所有模式都是理想的。本文将探讨 Go 中函数错误处理的最佳实践和反模式,并提供真实案例来进行演示。
最佳实践:
-
使用
errors.New()
创建错误:这是一个创建新错误的最常见方法,它可以返回带有简洁描述的error
值。 - 用底层错误包装错误:如果一个函数接到一个错误,可以将其包装在一个新的错误中,以提供关于错误来源的更多上下文。
-
返回
nil
表示没有错误:如果函数未遇到错误,则应返回nil
。 - 不要使用全局错误变量:使用全局错误变量会产生竞争条件,并使代码难以调试。
- 处理错误:所有错误都应在函数中处理,而不是将其忽略。理想情况下,应返回错误指示函数失败。
反模式:
- 使用魔数或固定的字符串表示错误:这会使代码难以维护和扩展。
-
隐式处理错误:不要使用
if err != nil { ... }
来检查错误,然后直接返回,因为这会使错误处理难以跟踪。 - 忽略错误:始终处理错误,即使你认为它们不太可能发生。
-
使用延迟退出模式:在函数末尾使用
if err != nil { return err }
的模式会使代码难以阅读和维护。
真实案例:
最佳实践:以下函数使用 errors.New()
创建一个新的错误,并返回它以向调用者指示文件打开失败:
func OpenFile(path string) (*os.File, error) { f, err := os.Open(path) if err != nil { return nil, errors.New("failed to open file: " + err.Error()) } return f, nil }