Golang如何处理函数返回错误

Go语言通过返回error类型实现错误处理,函数执行失败时返回非nil error值。例如divide函数在除数为0时返回fmt.Errorf错误,调用者需显式检查err是否为nil,否则可能被errcheck工具提示遗漏。除使用fmt.Errorf外,还可定义结构体如MyError实现error接口以携带更多信息。自Go 1.13起支持用%w包装错误,形成可追溯的错误链,配合errors.Unwrap、Is、As进行错误判断与解析。这种显式处理机制要求开发者主动应对错误,提升程序健壮性。

在Go语言中,错误处理是通过返回error类型值来实现的。函数执行失败时,通常会返回一个非nil的error,调用者需要显式检查这个错误,不能忽略。这是Go语言设计哲学的一部分:让错误处理清晰、明确。

函数如何返回错误

Go中的函数可以返回多个值,其中最后一个通常是error类型。例如:

func divide(a, b float64) (float64, error) {
    if b == 0 {
        return 0, fmt.Errorf("cannot divide by zero")
    }
    return a / b, nil
}

这里,如果除数为0,函数返回一个错误;否则返回计算结果和nil表示无错误。

调用函数时检查错误

调用上述函数时,必须检查第二个返回值是否为nil

result, err := divide(10, 2)
if err != nil {
    log.Fatal(err)
}
fmt.Println("Result:", result)

这种模式非常常见。如果不检查err,静态检查工具如errcheck会提示你遗漏了错误处理。

自定义错误类型

除了使用fmt.Errorf创建简单字符串错误,还可以定义结构体实现error接口:

type MyError struct {
    Code int
    Msg  string
}

func (e *MyError) Error() string {
    return fmt.Sprintf("[%d] %s", e.Code, e.Msg)
}

这样可以在错误中携带更多信息,便于后续判断或日志记录。

错误包装与追溯

从Go 1.13开始,支持使用%w格式化动词包装错误:

if err != nil {
    return fmt.Errorf("failed to process data: %w", err)
}

之后可以用errors.Unwraperrors.Iserrors.As来判断原始错误类型,适合构建可追溯的错误链。

基本上就这些。Go的错误处理不复杂,但要求开发者主动面对问题,而不是抛出异常让运行时处理。写好每一个if err != nil,程序才会更健壮。