errors.Join能合并多个错误,适用于需收集所有失败原因的场景,如表单验证或批量处理,相比传统“快速失败”,它实现错误的聚合传播,保留完整错误信息。

当你在Go语言中编写那些需要执行一系列操作,并且每个操作都可能独立失败的函数时,一个常见的问题是:如果多个操作都出错了,我该如何有效地报告所有这些错误,而不是只返回第一个?
errors.Join
在Go语言中,处理多个错误并将其合并成一个统一的错误返回,这在过去往往需要一些手动的工作,比如构建一个自定义的错误类型,或者用字符串拼接。但Go 1.20引入的
errors.Join
error
error
举个例子,假设我们有一个函数需要执行几个独立的验证步骤,任何一步失败都应该被记录下来:
package main
import (
"errors"
"fmt"
)
// 模拟一个验证函数
func validateInput(input string) error {
var errs []error
if len(input) == 0 {
errs = append(errs, errors.New("输入不能为空"))
}
if len(input) > 10 {
errs = append(errs, errors.New("输入长度不能超过10个字符"))
}
if !containsDigit(input) {
errs = append(errs, errors.New("输入必须包含至少一个数字"))
}
if len(errs) > 0 {
// 使用 errors.Join 合并所有收集到的错误
return errors.Join(errs...)
}
return nil
}
func containsDigit(s string) bool {
for _, r := range s {
if r >= '0' && r <= '9' {
return true
}
}
return false
}
func main() {
// 示例1: 有效输入
if err := validateInput("test123"); err != nil {
fmt.Println("验证失败:", err)
} else {
fmt.Println("验证成功")
}
// 示例2: 无效输入,多个错误
if err := validateInput(""); err != nil {
fmt.Println("验证失败:", err)
// 打印合并后的错误,会显示所有原始错误
// Output: 验证失败: 输入不能为空 (and 2 more errors)
}
// 示例3: 另一个无效输入
if err := validateInput("abcdefghijk"); err != nil {
fmt.Println("验证失败:", err)
// Output: 验证失败: 输入长度不能超过10个字符 (and 1 more error)
}
// 示例4: 包含多个错误
if err := validateInput("abc"); err != nil { // 长度OK,但没有数字
fmt.Println("验证失败:", err)
// Output: 验证失败: 输入必须包含至少一个数字
}
}运行上面的代码,你会看到
errors.Join
error1 (and X more errors)
立即学习“go语言免费学习笔记(深入)”;
什么时候用
errors.Join
errors.Join
errors.Join
我个人在使用中发现,它特别适用于那些“非致命性”错误的场景。比如,一个后台任务需要更新多个配置
以上就是Golang使用errors.Join合并多个错误的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号