Go语言通过多返回值机制将错误作为返回值,要求调用者显式检查,提升程序健壮性;例如divide函数返回结果和error,出错时返回非nil error;可使用fmt.Errorf创建简单错误,或定义实现error接口的结构体(如DivideError)携带更多上下文信息;通过errors.As进行类型断言以安全判断错误类型;建议始终处理error、避免忽略、合理构造并传递错误信息,利用errors.Is和errors.As进行现代错误比较与提取。

Go语言通过多返回值机制,尤其是将错误作为返回值之一,提供了一种清晰直接的错误处理方式。函数在出错时返回一个结果和一个error类型值,调用者必须显式检查错误,这增强了程序的健壮性和可读性。
基本错误返回模式
Go中常见的函数签名会同时返回结果和error。如果操作成功,error为nil;否则包含具体错误信息。
例如:
func divide(a, b float64) (float64, error) {if b == 0 {
return 0, fmt.Errorf("cannot divide by zero")
}
return a / b, nil
}
调用时需检查第二个返回值:
立即学习“go语言免费学习笔记(深入)”;
result, err := divide(10, 0)if err != nil {
fmt.Println("Error:", err)
return
}
fmt.Println("Result:", result)
自定义错误类型增强语义
除了使用fmt.Errorf,还可以定义实现error接口的结构体,携带更多上下文。
dividend float64
divisor float64
}
func (e *DivideError) Error() string {
return fmt.Sprintf("division error: %f / %f", e.dividend, e.divisor)
}
这样可以在返回错误时提供更多调试信息,便于定位问题。
错误判断与类型断言
当需要对特定错误做不同处理时,可以使用类型断言或errors.As来判断错误类型。
示例:
err := someOperation()var divErr *DivideError
if errors.As(err, &divErr) {
fmt.Printf("Caught divide error: %v\n", divErr)
}
这种方式避免了字符串比较,使错误处理更安全可靠。
统一错误处理建议
在实际项目中,推荐以下做法:
- 始终检查并处理返回的
error - 不忽略错误,即使是
_也应有注释说明原因 - 使用
errors.New或fmt.Errorf创建简单错误 - 对于复杂场景,定义有意义的错误类型
- 利用
errors.Is和errors.As进行现代错误比较与提取
基本上就这些。Go的多返回值让错误处理变得直观,关键是养成主动检查错误的习惯,并合理构造和传递错误信息。










