Go 中判断 IO 错误应使用 errors.Is 和 errors.As:errors.Is 用于匹配哨兵值(如 fs.ErrNotExist、io.EOF),errors.As 用于安全断言具体类型(如 os.PathError、net.OpError),二者可穿透错误包装,避免字符串匹配或直接比较。

Go 中判断一个 error 是否是 IO 错误,不能靠字符串匹配或简单比较,而要依靠标准库提供的类型断言和错误分类工具——核心是 errors.Is 和 errors.As,配合 *os.PathError、*os.SyscallError、fs.ErrNotExist 等具体类型或哨兵值。
IO 错误通常以指针形式返回(如 *os.PathError),所以要用 errors.As 进行安全类型断言:
var pathErr *os.PathError,然后 if errors.As(err, &pathErr) { ... } 可提取路径、操作名、底层系统错误等信息var sysErr *os.SyscallError,适用于底层 syscall 失败(如 connect: connection refused)var pe *net.OpError,常见于网络 IO(如 dial timeout、read deadline exceeded)标准库预定义了一批可复用的哨兵错误,适合做语义判断:
errors.Is(err, fs.ErrNotExist) → 文件/目录不存在(比 os.IsNotExist(err) 更推荐)errors.Is(err, io.EOF) → 读取到流末尾(注意:这不是异常,是正常终止信号)errors.Is(err, os.ErrPermission) → 权限不足errors.Is(err, os.ErrExist) → 文件已存在(常用于 os.Create 冲突)不是所有带 io. 或 os. 前缀的 error 都算“IO错误”;关键看它是否源于系统调用或文件描述符操作:
os.Open、file.Read、os.Stat、http.Get(底层 TCP 连接)、json.Unmarshal(从 io.Reader 读时出错)fmt.Errorf("xxx")、自定义业务错误、strconv.Atoi 解析失败、JSON 语法错误(json.SyntaxError 是解析逻辑错误,非 IO)io.EOF 是 io 包定义的哨兵值,但语义上代表“正常结束”,不应当作异常处理以下做法不推荐,容易失效或不可维护:
err.Error() == "no such file or directory" —— 字符串依赖操作系统语言和版本,且会被 fmt.Errorf(... %w) 包装后失效err == os.ErrNotExist —— 若错误被包装(如 fmt.Errorf("read config: %w", err)),等式比较会失败errors.Is 或 errors.As,它们能穿透多层错误包装(%w)基本上就这些。IO 错误判断的关键不在“是不是来自 os/io 包”,而在于“能不能用标准方式识别其本质原因”。用对 errors.Is 和 errors.As,就能稳住错误分类逻辑,不被包装干扰,也不受语言环境影响。
以上就是Go如何判断一个error是否是io错误_Go IO Error分类解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号