是,go mod tidy 会自动删除未使用的依赖,但仅当模块为主模块且无其他模块显式 require 时,它基于构建图做可达性分析而非简单扫描 import。

会,但只在模块处于“主模块”(即当前目录有 go.mod 且 GO111MODULE=on)且没有其他模块显式 require 它时才删除。它不是简单地扫描 import 语句,而是基于整个构建图做可达性分析:
go mod tidy会重新计算所有
import 路径的传递闭包,移除不在该闭包中的 require 条目。
常见误判场景:
_ "some/module" 方式导入但没实际调用 —— go mod tidy 仍会保留,因为下划线导入本身就算使用*_test.go)里用了某模块,但主代码没用 —— 默认会保留,除非加 -compat=1.16 或更高版本且测试未被 go test 实际触发//go:embed 或 //go:generate 引用某包,但没 import —— 不会被识别为依赖,go mod tidy 会误删别直接改 go.mod 文件手动编辑版本号,容易出错。推荐用 go get 显式升级:
go get example.com/some/module@latest
go get example.com/some/module@v1.2.3
go get example.com/some/module@abcd123
go get 直接依赖,再 go mod tidy 推导注意:go get 默认会写入 go.mod 并自动运行 go mod tidy(Go 1.16+),但不会自动 go mod vendor。
go mod tidy 只管 go.mod 和 go.sum,和 vendor/ 无关。要同步 vendor,必须额外执行:
go mod vendor
常见疏漏点:
-v 参数时,go mod vendor 默认只 vendoring 构建所需模块,不包含测试依赖 —— 如需完整复制,用 go mod vendor -v
go.mod 已是最新的(比如刚 go get 但忘了 go mod tidy),会导致 vendor 内容陈旧GOPROXY=off,go mod vendor 会失败,因无法拉取 module zip 包go.sum 不是“可合并”的文本文件,它是每个 module 的校验和快照。多人协作时出现冲突,**不要手动编辑或删行**。正确做法是:
git checkout 拿到双方的 go.mod(可能已合并好)go mod tidy—— 它会重生成
go.sum,覆盖所有冲突内容verify failed 错误;若有,说明某 module 的哈希不匹配,可能是中间人篡改或缓存污染,需清空 $GOPATH/pkg/mod/cache 后重试关键点:只要 go.mod 正确,go.sum 就可完全重建;它的作用只是校验,不是状态记录。