Go语言通过显式返回error类型处理错误,调用者需主动检查并处理。1. 函数执行后返回error,nil表示成功,非nil表示失败,必须判断err避免忽略错误。2. 使用fmt.Errorf搭配%w包装错误,保留原始错误链,便于使用errors.Is或errors.As进行比较和类型断言。3. 可定义实现error接口的结构体携带额外信息(如Code、Message),用于HTTP状态码映射等场景。4. 在panic场景下,通过defer配合recover捕获异常并转为普通错误,但应仅用于不可恢复或第三方库引发的panic。Go强调错误路径清晰可控,合理组合返回、包装、自定义与恢复机制可提升代码健壮性。

Go语言中错误处理的核心是显式处理错误,不依赖异常机制。函数通过返回error类型来表示失败,调用者必须主动检查并处理。以下是常见的错误处理方式。
这是最基础也是最常用的错误处理方式。函数执行可能出错的操作后,返回一个error值,调用方通过判断是否为nil来决定后续逻辑。
示例:
func readFile(filename string) ([]byte, error) {
data, err := os.ReadFile(filename)
if err != nil {
return nil, err
}
return data, nil
}
// 调用时
data, err := readFile("config.json")
if err != nil {
log.Fatal("读取文件失败:", err)
}
关键点:每个可能出错的操作都应检查err,避免忽略错误导致程序行为异常。
立即学习“go语言免费学习笔记(深入)”;
从Go 1.13开始,支持使用%w格式化动词包装错误,保留原始错误链,便于排查问题根源。
示例:
if err != nil {
return fmt.Errorf("解析配置失败: %w", err)
}
之后可以用errors.Is和errors.As进行错误比较或类型断言:
if errors.Is(err, os.ErrNotExist) {
// 处理文件不存在
}
if target := &MyCustomError{}; errors.As(err, target) {
// 处理特定类型的错误
}
当需要携带额外上下文(如状态码、重试建议等)时,可以定义实现了error接口的结构体。
示例:
type AppError struct {
Code int
Message string
Err error
}
func (e *AppError) Error() string {
return fmt.Sprintf("[%d] %s: %v", e.Code, e.Message, e.Err)
}
// 使用
return &AppError{Code: 400, Message: "参数无效", Err: err}
这样可以在上层根据Code做不同处理,比如HTTP响应状态码映射。
虽然Go推荐用error而非panic控制流程,但在某些库或不可恢复场景中仍可能触发panic。可通过defer结合recover捕获并转为普通错误。
示例:
defer func() {
if r := recover(); r != nil {
err = fmt.Errorf("发生panic: %v", r)
}
}()
注意:这种方式应谨慎使用,仅适用于无法避免的panic场景,比如第三方库调用或初始化阶段。
基本上就这些。Go的错误处理强调清晰和可控,不隐藏失败路径。合理使用error返回、包装、自定义类型和recover机制,能写出健壮的服务代码。
以上就是Golang错误处理常见方式有哪些的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号