go的间接依赖为什么不会主动更新 go build参数?

[更新]
·
·
分类:互联网
4146 阅读

go

go build参数?

build参数?

go build [-o 输出名] [-i] [编译标记] [包名]
如果参数为***.go文件或文件列表,则编译为一个个单独的包。
当编译单个main包(文件),则生成可执行文件。
当编译单个或多个包非主包时,只构建编译包,但丢弃生成的对象(.a),仅用作检查包可以构建。
当编译包时,会自动忽略_test.go的测试文件。
-o
output 指定编译输出的名称,代替默认的包名。
-i
install 安装作为目标的依赖关系的包(用于增量编译提速)。
以下 build 参数可用在 build, clean, get, install, list, run, test
-a
完全编译,不理会-i产生的.a文件(文件会比不带-a的编译出来要大?)
-n
仅打印输出build需要的命令,不执行build动作(少用)。
-p n
开多少核cpu来并行编译,默认为本机CPU核数(少用)。
-race
同时检测数据竞争状态,只支持 linux/amd64, freebsd/amd64, darwin/amd64 和 windows/amd64.
-msan
启用与内存消毒器的互操作。仅支持linux / amd64,并且只用Clang / LLVM作为主机C编译器(少用)。
-v
打印出被编译的包名(少用).
-work
打印临时工作目录的名称,并在退出时不删除它(少用)。
-x
同时打印输出执行的命令名(-n)(少用).
-asmflags flag list
传递每个go工具asm调用的参数(少用)
-buildmode mode
编译模式(少用)
go help buildmode
-compiler name
使用的编译器
(gccgo or gc)(少用).
-gccgoflags arg list
gccgo 编译/链接器参数(少用)
-gcflags arg list
垃圾回收参数(少用).
-installsuffix suffix
a suffix to use in the name of the package installation directory,
in order to keep output separate from default builds.
If using the -race flag, the install suffix is automatically set to race
or, if set explicitly, has _race appended to it. Likewise for the -msan
flag. Using a -buildmode option that requires non-default compile flags
has a similar effect.
-ldflags flag list
-s -w: 压缩编译后的体积
-s: 去掉符号表
-w: 去掉调试信息,不能gdb调试了
-linkshared
链接到以前使用创建的共享库
-buildmodeshared.
-pkgdir dir
从指定位置,而不是通常的位置安装和加载所有软件包。例如,当使用非标准配置构建时,使用-pkgdir将生成的包保留在单独的位置。
-tags tag list
构建出带tag的版本.
-toolexec cmd args
a program to use to invoke toolchain programs like vet and asm.
For example, instead of running asm, the go command will run
cmd args /path/to/asm ltarguments for asmgt.
以上命令,单引号/双引号均可。
对包的操作go help packages
对路径的描述go help gopath
对 C/C 的互操作go help c
构建遵守某些约定(go help gopath),但不是所有的项目都遵循这些约定,当使用自己的惯例或使用单独的软件构建系统时可以选择使用较低级别的调用go tool compile和go tool link来避免一些构建工具的开销和设计决策

go语言现在很重要么? ?

Golang,一句话:它的好,谁用谁知道。