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() 创建简单错误:
立即学习“go语言免费学习笔记(深入)”;
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 就够了。










