Go 1.13引入错误包装机制,通过fmt.Errorf配合%w动词添加上下文而不丢失原错误,如err := fmt.Errorf("读取配置失败: %w", originalErr);使用errors.Unwrap可提取被包装的底层错误。为判断错误是否匹配目标或类型,应优先使用errors.Is(err, target)和errors.As(err, &target),而非直接比较。建议在调用链中适度添加上下文以提升调试效率,例如将“打开文件失败”包装为“加载用户配置失败”,但避免重复包装导致冗余。公开API宜定义可包装的自定义错误类型,便于调用方识别处理。合理结合%w、Is和As形成一致错误处理模式,可显著提升程序健壮性与日志可读性。

在Go语言中,错误处理是程序健壮性的重要组成部分。从Go 1.13开始引入的错误包装(Error Wrapping)机制,让开发者可以在不丢失原始错误信息的前提下,添加上下文信息,从而提升错误的可读性和调试效率。
使用 fmt.Errorf 配合 %w 动词可以实现错误包装。被包装的错误会成为新错误的“底层原因”,后续可通过 errors.Unwrap 提取。
示例:
err := fmt.Errorf("failed to read config: %w", originalErr)
这里 %w 表示将 originalErr 包装进新错误中。注意:一个 fmt.Errorf 调用只能使用一个 %w。
立即学习“go语言免费学习笔记(深入)”;
当需要判断某个错误是否由特定类型引起时,应使用 errors.Is 和 errors.As,而不是直接比较。
例如:
if errors.Is(err, os.ErrNotExist) {
log.Println("文件不存在")
}
var pathErr *os.PathError
if errors.As(err, &pathErr) {
log.Printf("路径错误,操作: %s, 路径: %s\n", pathErr.Op, pathErr.Path)
}
在函数调用链中传递错误时,适当添加上下文有助于定位问题,但不要过度包装。
基本上就这些。合理使用错误包装能让日志和调试更清晰,关键是结合 %w、Is 和 As 形成一致的错误处理模式。
以上就是Golang错误包装与传递如何使用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号