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: %sn", 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 就够了。