要集成 errcheck 进行 golang 错误检查,1. 安装 errcheck 使用 go install github.com/kisielk/errcheck@latest;2. 在项目根目录运行 errcheck ./… 或指定路径进行检查;3. 将 errcheck 集成到 vs code 等 ide 中实现自动检测;4. 在 github actions 等 ci 流程中添加 errcheck 步骤以防止错误代码提交。
配置 Golang 的自动化错误检查时,集成
errcheck
是一个非常实用的做法。它能帮助你在编译前发现那些被忽略的错误处理代码,避免上线后出现意料之外的问题。这篇文章主要讲怎么把 errcheck 集成进你的开发流程中,让它在合适的时间点自动运行。
安装 errcheck
要使用 errcheck,首先得把它安装到本地环境里。你可以通过 go install 命令来完成这一步:
go install github.com/kisielk/errcheck@latest
安装完成后,可以运行
errcheck --help
来确认是否成功。如果看到命令的帮助信息,说明已经安装好了。
立即学习“go语言免费学习笔记(深入)”;
有时候你可能用的是较新的 Go 版本,而 errcheck 的某些版本对新特性支持不够好,这时候建议使用最新版或者特定分支。例如:
- 使用 dev 分支:
go install github.com/kisielk/errcheck@dev
- 或者 fork 后的替代版本,比如
github.com/mdempsky/unconvert
这类工具也常被搭配使用。
在项目中启用 errcheck 检查
安装完之后,下一步是让 errcheck 能跑起来。最简单的办法就是在项目根目录执行下面这个命令:
errcheck ./...
这条命令会扫描整个项目,找出所有忽略了 error 返回值的地方。比如:
_, _ = fmt.Fprintf(w, "hello") // 没有处理 error
这种情况会被 errcheck 抓出来,并提示你修复。
如果你只想检查某个包或文件夹,可以替换
./...
为具体的路径,比如
errcheck ./pkg/utils
。
不过每次手动运行也不太方便,所以更推荐下面这两种方式让它自动跑起来。
集成到 IDE(如 VS Code)
很多开发者都在用 VS Code 写 Go 程序,那就可以把这个静态检查工具集成进去。步骤如下:
- 打开 VS Code 设置(Preferences > Settings)
- 搜索 “Go: Tools”
- 添加一个新的 entry 到 “go.tools” 列表里,内容类似:
{ "tool": "errcheck", "name": "ErrCheck", "type": "linter" }
- 然后确保 “Go: Enable ErrCheck” 这个选项是打开的
这样设置之后,VS Code 就会在你写代码的时候自动调用 errcheck,并在编辑器中标出问题行。这对快速发现问题很有帮助。
注意:不同 IDE 的插件支持程度略有差异,有些需要额外配置 lint 工具路径,或者选择特定的 linter 模式。
加入 CI 流程(如 GitHub Actions)
除了本地开发时使用,最好还能在 CI 阶段加上这一层检查。以 GitHub Actions 为例,可以在
.github/workflows/ci.yml
文件里添加一个 job:
- name: Run errcheck run: | go install github.com/kisielk/errcheck@latest errcheck -blank ./...
其中
-blank
参数表示只检查那些返回了 error 却完全没处理的情况(也就是
_ = someFunc()
这种)。这个参数比较常用,也能减少一些误报。
如果你希望更严格一点,也可以去掉
-blank
,让 errcheck 对所有未处理 error 的情况都报错。
CI 中集成的好处在于:即使个别开发者漏掉了本地检查,也不会提交有问题的代码。
基本上就这些。
errcheck 虽然不能覆盖所有错误处理场景,但能帮你抓住最常见的“忘掉 error”的问题。配合 IDE 和 CI 使用,效果更好。刚开始可能会觉得有点烦,但时间一长你会发现它确实能提高代码质量。
评论(已关闭)
评论已关闭