验证Go安装需依次检查:1. go version输出正确版本;2. PATH含Go的bin目录且无多版本冲突;3. GOROOT指向安装根目录、GOENV可写;4. 编译运行main.go输出"hello, go";5. go mod init与go mod tidy成功拉取依赖。
go 命令是否可用且版本正确安装完成后最直接的

go 命令,并输出预期版本。常见错误是 PATH 未更新或安装包损坏,导致提示 command not found: go 或版本明显过旧(如 go version go1.16.15 而你安装的是 1.22)。
go version,应输出类似 go version go1.22.3 darwin/arm64 的信息$PATH 是否包含 Go 的 bin 目录(Linux/macOS 通常是 $HOME/go/bin 或 /usr/local/go/bin;Windows 是 %USERPROFILE%\go\bin 或 C:\Go\bin)which go(macOS/Linux)或 where go(Windows)确认二进制路径,避免多个版本冲突GOROOT 和 GOENV 环境变量是否合理Go 工具链依赖 GOROOT 指向安装根目录,GOENV 控制配置文件位置。错误设置会导致 go install 失败、模块缓存异常或 go env -w 不生效。
go env GOROOT,输出应为实际安装路径(如 /usr/local/go),不能是空或指向用户目录go env GOENV,默认是 $HOME/.config/go/env(Linux)、$HOME/Library/Application Support/go/env(macOS)或 %USERPROFILE%\AppData\Roaming\go\env(Windows);若被手动设为 off,则所有 go env -w 配置将被忽略go env -u GOPROXY 测试写入权限——若提示 cannot unset environment variable,说明 GOENV 不可写或被禁用main.go 编译并执行仅检查命令存在和环境变量还不够,必须验证编译器前端(lexer/parser)、后端(linker)和运行时(runtime)三者协同正常。典型失败包括 CGO_ENABLED=1 时缺少 gcc、交叉编译目标不支持、或 GOOS/GOARCH 错误覆盖本地构建。
package main
import "fmt"
func main() {
fmt.Println("hello, go")
}go build -o hello .,成功后应生成可执行文件;若报错 cannot find package "fmt",说明 GOROOT 错误或标准库缺失./hello,输出 hello, go;若提示 permission denied(Linux/macOS),需 chmod +x hello;若 Windows 报 不是有效的 Win32 应用程序,可能是 GOOS=linux 污染了环境现代 Go 项目强依赖模块系统,验证 go mod 能力比单纯编译更贴近真实使用场景。失败常因网络策略、私有仓库认证缺失,或 GOPROXY 设为 direct 后无法访问公网模块。
go mod init example.com/test,应生成 go.mod 文件import "golang.org/x/tools/gopls" 到 main.go,再执行 go mod tidy
no required module provides package,检查 go env GOPROXY;国内推荐设为 https://goproxy.cn,direct,用 go env -w GOPROXY=https://goproxy.cn,direct 永久生效go mod download 默认只下载 go.sum 中记录的版本,若想强制刷新远程最新版,需先 go clean -modcache
GOROOT 手动设置后又装了新版本,或公司脚本自动注入了冲突的 GOOS。每次重装或切换 SDK 后,建议优先跑一遍 go env 全量输出,而不是只看 go version。