
Go 语言优雅错误处理:兼顾return error和自定义错误码
Go 语言中,return error 是常见的错误处理方式,但它无法直接返回自定义错误码,这在需要特定错误码的接口场景下显得不够灵活。 直接使用包含错误码和消息的自定义结构体虽然可行,却偏离了 Go 的惯例。 本文探讨更优雅的解决方案。
Go 1.14 及以上版本的解决方案:利用errors.Is和errors.As
Go 1.13 引入的 errors.Is 和 errors.As 函数为优雅地处理自定义错误码提供了支持。 我们可以创建自定义错误类型,并利用这些函数在错误处理中提取错误码信息,无需改变 return error 的习惯。
立即学习“go语言免费学习笔记(深入)”;
package main
import (
"errors"
"fmt"
)
// 自定义错误类型
type MyError struct {
Code int
Message string
}
func (e *MyError) Error() string {
return fmt.Sprintf("Error code %d: %s", e.Code, e.Message)
}
// 模拟一个返回错误的函数
func myFunc() error {
// 模拟错误发生
return &MyError{Code: 1001, Message: "操作失败"}
}
func main() {
err := myFunc()
if err != nil {
var myErr *MyError
if errors.As(err, &myErr) { // 使用 errors.As 提取自定义错误
fmt.Printf("Error code: %d, Message: %s\n", myErr.Code, myErr.Message)
} else {
fmt.Println("Unknown error:", err)
}
if errors.Is(err, &MyError{Code: 1001, Message: ""}) { // 使用 errors.Is 检查特定错误码
fmt.Println("Specific error 1001 occurred")
}
}
}
通过自定义错误类型和 errors.Is/errors.As,我们可以既保持 return error 的简洁性,又能够方便地获取和处理自定义错误码,从而实现更优雅的错误处理。 这比使用自定义结构体更符合 Go 的风格,也更易于维护和理解。










