Go函数常返回结果与错误,需始终检查error类型以确保程序健壮性。通常最后一个返回值为error,调用时应先判断err是否为nil再使用其他值。自Go 1.13起可用fmt.Errorf包装错误,Go 1.20引入errors.Join可合并多个非nil错误,便于批量操作中收集全部失败信息。对于复杂场景,可定义MultiError结构体聚合多个错误并实现Error方法返回组合消息,还可支持Is或As接口进行错误断言。避免使用下划线忽略错误,除非明确知晓可安全忽略并添加注释说明。正确处理多错误返回值的关键是显式检查、合理聚合与上下文传递。

在Go语言中,函数经常需要返回多个错误值或同时返回结果与错误。正确处理多错误返回值对程序的健壮性至关重要。Go没有异常机制,而是通过显式返回error类型来表示失败,因此开发者必须主动检查并处理这些错误。
理解多返回值中的错误位置
Go函数可以返回多个值,通常最后一个返回值是error类型。例如:
if b == 0 {
return 0, errors.New("division by zero")
}
return a / b, nil
}
调用时必须同时接收结果和错误:
result, err := divide(10, 0)if err != nil {
log.Fatal(err)
}
即使函数返回多个值,也应始终检查err是否为nil再使用其他返回值。
立即学习“go语言免费学习笔记(深入)”;
组合多个错误(Go 1.13+)
当需要返回多个错误时,可以使用fmt.Errorf包装错误,或利用Go 1.13引入的errors.Join(Go 1.20+)合并多个错误:
err2 := doSecond()
err := errors.Join(err1, err2)
if err != nil {
return err
}
errors.Join会将多个非nil错误合并成一个复合错误,打印时会显示所有子错误。适合批量操作中收集全部失败信息。
自定义错误类型聚合
对于更复杂的场景,可定义结构体保存多个错误:
type MultiError struct {Errors []error
}
func (m *MultiError) Error() string {
var msgs []string
for _, e := range m.Errors {
msgs = append(msgs, e.Error())
}
return strings.Join(msgs, "; ")
}
使用示例:
var multiErr MultiErrorif err := op1(); err != nil {
multiErr.Errors = append(multiErr.Errors, err)
}
if err := op2(); err != nil {
multiErr.Errors = append(multiErr.Errors, err)
}
if len(multiErr.Errors) > 0 {
return &multiErr
}
这种方式便于在后续逻辑中遍历具体错误,也可实现Is或As方法支持错误断言。
避免忽略错误
不要用下划线忽略错误值,除非明确知道可以安全忽略:
// 不推荐result, _ := riskyOperation()
若确实无需处理,应添加注释说明原因:
// 忽略错误:配置项可选,不存在时不影响流程value, _ := readConfig("optional_key")
基本上就这些。关键是始终检查错误,合理聚合,并确保调用方能获取足够的上下文信息。Go的设计鼓励显式错误处理,善用标准库和自定义类型能让多错误管理更清晰。










