Go 1.13增强errors包,支持错误包装(%w)、errors.Is判断相等、errors.As提取类型,推荐底层返回具体错误、中间层添加上下文、顶层分类处理,提升错误可读性与维护性。

Go语言从1.13版本开始对 errors 包进行了增强,引入了错误包装(error wrapping)、错误判定和错误类型提取等功能,使错误处理更加灵活和语义化。合理使用 errors 包能提升程序的可维护性和调试效率。
在实际开发中,底层函数返回错误时,上层函数往往需要添加上下文信息以便于定位问题。Go 通过 %w 动词实现错误包装。
注意:%w 只能用于 fmt.Errorf,且只能包装一个错误。示例:
package main
import (
"errors"
"fmt"
)
func readFile() error {
return fmt.Errorf("读取文件失败: %w", errors.New("文件不存在"))
}
func processFile() error {
return fmt.Errorf("处理文件出错: %w", readFile())
}
func main() {
err := processFile()
fmt.Println(err) // 输出:处理文件出错: 读取文件失败: 文件不存在
}
当需要判断某个错误链中是否包含特定错误时,使用 errors.Is 比 == 更安全,因为它会递归检查被包装的错误。
立即学习“go语言免费学习笔记(深入)”;
示例:
target := errors.New("连接超时")
err := fmt.Errorf("网络请求失败: %w", target)
if errors.Is(err, target) {
fmt.Println("捕获到连接超时错误")
}
即使错误被多层包装,errors.Is 也能正确匹配目标错误。
当错误链中可能包含自定义结构体错误时,可用 errors.As 提取对应类型的变量,便于访问其字段或方法。
示例:
type MyError struct {
Code int
Msg string
}
func (e *MyError) Error() string {
return fmt.Sprintf("错误码 %d: %s", e.Code, e.Msg)
}
func doSomething() error {
return fmt.Errorf("操作失败: %w", &MyError{Code: 404, Msg: "未找到资源"})
}
func main() {
err := doSomething()
var myErr *MyError
if errors.As(err, &myErr) {
fmt.Printf("错误码: %d, 消息: %s\n", myErr.Code, myErr.Msg)
}
}
这段代码成功从包装错误中提取出 *MyError 类型实例。
在实际项目中,推荐以下做法:
基本上就这些。掌握 errors 包的核心功能后,可以写出更清晰、易调试的 Go 错误处理逻辑。关键是理解包装链的结构以及 Is/As 的递归查找机制。不复杂但容易忽略细节。
以上就是如何使用Golang的errors包_Golang标准错误库功能与应用示例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号