
在这部分,我们将通过一个表格来快速浏览Go语言的所有内建命令及其基本功能。这些命令涵盖了从代码构建、测试,到依赖管理和其他工具等方面。
| 命令 | 功能描述 |
|---|---|
go build | 编译Go源文件 |
go run | 编译并运行Go程序 |
go get | 下载并安装依赖或项目 |
go mod | Go模块支持 |
go list | 列出包或模块 |
go fmt | 格式化代码 |
go vet | 静态检查代码 |
go test | 运行测试 |
go doc | 查看文档 |
go env | 打印Go环境信息 |
go clean | 删除编译生成的文件 |
go tool | 运行指定的go工具 |
go version | 打印Go当前版本 |
go install | 编译和安装Go程序或库 |
go generate | 通过处理源生成Go文件 |
go fix | 更新包以使用新的API |
go workspace | 管理Go工作区(实验性) |
go help | 查看命令或主题的帮助信息 |
这个表格提供了一个快速参考,使你能更方便地理解每个命令的基本用途。

在这一部分,我们将逐一介绍上述表格中的Go命令。我们将探讨每个命令的详细说明、使用场景,以及命令使用后的实际返回案例。
go build命令用于编译Go源文件。该命令会根据源代码生成可执行文件或库。
- $ go build hello.go
- # 无输出,但会生成一个名为hello的可执行文件
go run命令用于编译并运行Go程序。适用于快速测试代码片段。
- $ go run hello.go
- Hello, world!
go get用于下载并安装依赖或项目。
- $ go get github.com/gin-gonic/gin
- # 下载并安装gin库,无输出
go mod用于Go模块支持,包括初始化、添加依赖等。
- $ go mod init my-module
- go: creating new go.mod: module my-module
go list用于列出包或模块。
- $ go list ./...
- # 列出当前项目所有包
go fmt用于自动格式化Go源代码。
- $ go fmt hello.go
- # 格式化hello.go文件,返回格式化后的文件名
- hello.go
go vet用于对Go代码进行静态分析,检查可能存在的错误。
- $ go vet hello.go
- # 若代码无问题,则没有输出
go test用于运行Go程序的测试。
- $ go test
- ok github.com/yourusername/yourpackage 0.002s
go doc用于查看Go语言标准库或你的代码库中的文档。
- $ go doc fmt.Println
- func Println(a ...interface{}) (n int, err error)
go env用于打印Go的环境信息。
- $ go env
- GOARCH="amd64"
- GOBIN=""
- ...
go clean用于删除编译生成的文件。
- $ go clean
- # 删除编译生成的文件,无输出
go tool用于运行指定的Go工具。
- $ go tool compile hello.go
- # 编译hello.go,生成中间文件
go version用于打印当前Go的版本信息。
- $ go version
- go version go1.17.1 linux/amd64
go install用于编译和安装Go程序或库。
- $ go install hello.go
- # 编译并安装hello程序,无输出
go generate用于通过处理源代码来生成Go文件。
- $ go generate
- # 运行生成指令,生成代码,无输出
go fix用于更新包以使用新的API。
- $ go fix oldpackage
- # 更新oldpackage包的API调用,无输出
go workspace用于管理Go工作区。这是一个实验性功能。
- $ go workspace create myworkspace
- # 创建名为myworkspace的工作区,无输出
go help用于查看命令或主题的帮助信息。
- $ go help build
- # 显示go build命令的详细帮助信息