使用 errors.Is 和 errors.As 精准判断可预期错误,如文件不存在或超时,可安全跳过;通过类型断言或封装函数提高代码可读性,避免无差别忽略错误,确保程序健壮性。

在Go语言开发中,经常会遇到一些可预期的错误,比如文件不存在、网络连接超时等。这类错误并不需要中断程序执行,只需适当处理或直接忽略即可。关键在于明确判断错误类型,避免误放不可忽略的错误。
1. 使用 errors.Is 判断特定错误
Go 1.13+ 推荐使用 errors.Is 来判断是否为某个预期内的错误,比如忽略“文件不存在”:
file, err := os.Open("config.txt")
if err != nil {
if errors.Is(err, os.ErrNotExist) {
// 文件不存在是可接受的,跳过
log.Println("配置文件未找到,使用默认配置")
} else {
// 其他错误需要处理
return err
}
}
2. 使用类型断言或 errors.As 处理自定义错误
当错误来自第三方库或自定义类型时,可用 errors.As 提取具体错误类型:
if err != nil {
var pathError *os.PathError
if errors.As(err, &pathError) {
log.Printf("路径错误: %v, 忽略并继续", pathError)
return nil // 安全跳过
} else {
return err // 其他错误返回
}
}
3. 定义可忽略错误的场景
常见可忽略错误包括:
立即学习“go语言免费学习笔记(深入)”;
- os.ErrNotExist:文件或目录不存在
- context.DeadlineExceeded:超时错误(可重试)
- net.ErrClosed:连接已关闭
- io.EOF:读取到结尾(在某些场景下可忽略)
注意:不要无差别忽略 err != nil,必须判断错误语义是否安全。
4. 封装判断逻辑提高可读性
对于频繁判断的错误,可封装为函数:
func isExpectedError(err error) bool {
return errors.Is(err, os.ErrNotExist) ||
errors.Is(err, context.DeadlineExceeded)
}
if err != nil && !isExpectedError(err) {
return err
}
// 忽略预期错误,继续执行
基本上就这些。关键是区分“可预期、可恢复”和“真正异常”的错误,用 errors.Is 或 errors.As 精准判断,避免掩盖潜在问题。安全跳过不等于盲目忽略。










