如何在Golang中使用errors处理错误

Go通过返回error接口处理错误,使用errors.New和fmt.Errorf创建错误;2. 用errors.Is和errors.As判断和解析错误类型;3. 可自定义错误结构体实现Error方法以携带上下文。

在Golang中处理错误是编写健壮程序的重要部分。Go没有异常机制,而是通过返回error类型来显式处理错误。正确使用errors包和相关模式,能让你的代码更清晰、更可靠。

理解 error 类型

error 是 Go 内置的接口类型:

type error interface {
    Error() string
}

任何实现了 Error() 方法的类型都可以作为错误使用。大多数情况下,你只需使用标准库提供的错误构造方式。

最常见的是使用 errors.New() 创建简单错误:

import "errors"

func divide(a, b float64) (float64, error) {
    if b == 0 {
        return 0, errors.New("division by zero")
    }
    return a / b, nil
}

使用 fmt.Errorf 带格式的错误

当你需要包含动态信息时,用 fmt.Errorf 更方便:

import "fmt"

func readFile(name string) error {
    // 模拟文件不存在
    return fmt.Errorf("could not open file %s: permission denied", name)
}

这样可以将变量值嵌入错误消息中,便于调试。

判断和处理特定错误

有时你需要根据错误类型做出不同反应。可以用以下几种方式:

1. 使用 errors.Is 判断错误是否匹配
err := someFunc()
if errors.Is(err, io.EOF) {
    // 处理文件结束
}
2. 使用 errors.As 提取具体错误类型
var pathError *os.PathError
if errors.As(err, &pathError) {
    fmt.Printf("Failed at path: %s\n", pathError.Path)
}

这在你想访问错误的具体字段时非常有用。

自定义错误类型

对于复杂场景,可以定义自己的错误类型:

type MyError struct {
    Code    int
    Message string
}

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

// 使用
return &MyError{Code: 404, Message: "not found"}

这样调用方可以通过类型断言获取更多上下文信息。

基本上就这些。关键是保持错误处理简洁,只在必要时展开细节,多数时候直接返回或检查 err != nil 就够了。