go语言编译模块 go语言编译过程

GO语言(二十七):管理依赖项(下)-当您对外部模块的存储库进行了 fork (例如修复模块代码中的问题或添加功能)时 , 您可以让 Go 工具将您的 fork 用于模块的源代码 。这对于测试您自己的代码的更改很有用 。
为此,您可以使用go.mod 文件中的replace指令将外部模块的原始模块路径替换为存储库中 fork 的路径 。这指示 Go 工具在编译时使用替换路径(fork 的位置) , 例如,同时允许您保留import 原始模块路径中的语句不变 。
在以下 go.mod 文件示例中,当前模块需要外部模块example.com/theirmodule 。然后该replace指令将原始模块路径替换为example.com/myfork/theirmodule模块自己的存储库的分支 。
设置require/replace对时,使用 Go 工具命令确保文件描述的需求保持一致 。使用go list命令获取当前模块正在使用的版本 。然后使用go mod edit命令将需要的模块替换为fork:
注意:当您使用该replace指令时,Go 工具不会像添加依赖项中所述对外部模块进行身份验证 。
您可以使用go get命令从其存储库中的特定提交为模块添加未发布的代码 。
为此,您使用go get命令,用符号@指定您想要的代码。当您使用go get时,该命令将向您的 go.mod 文件添加一个 需要外部模块的require指令 , 使用基于有关提交的详细信息的伪版本号 。
以下示例提供了一些说明 。这些基于源位于 git 存储库中的模块 。
当您的代码不再使用模块中的任何包时,您可以停止将该模块作为依赖项进行跟踪 。
要停止跟踪所有未使用的模块,请运行go mod tidy 命令 。此命令还可能添加在模块中构建包所需的缺失依赖项 。
要删除特定依赖项 , 请使用go get,指定模块的模块路径并附加 @none , 如下例所示:
go get命令还将降级或删除依赖于已删除模块的其他依赖项 。
当您使用 Go 工具处理模块时,这些工具默认从 proxy.golang.org(一个公共的 Google 运行的模块镜像)或直接从模块的存储库下载模块 。您可以指定 Go 工具应该使用另一个代理服务器来下载和验证模块 。
如果您(或您的团队)已经设置或选择了您想要使用的不同模块代理服务器,您可能想要这样做 。例如,有些人设置了模块代理服务器,以便更好地控制依赖项的使用方式 。
要为 Go 工具指定另一个模块代理服务器 , 请将GOPROXY 环境变量设置为一个或多个服务器的 URL 。Go 工具将按照您指定的顺序尝试每个 URL 。默认情况下,GOPROXY首先指定一个公共的 Google 运行模块代理,然后从模块的存储库直接下载(在其模块路径中指定):
您可以将变量设置为其他模块代理服务器的 URL,用逗号或管道分隔 URL 。
Go 模块经常在公共互联网上不可用的版本控制服务器和模块代理上开发和分发 。您可以设置 GOPRIVATE环境变量 。您可以设置GOPRIVATE环境变量来配置go命令以从私有源下载和构建模块 。然后 go 命令可以从私有源下载和构建模块 。
GOPRIVATE或环境变量可以设置为匹配模块前缀的全局模式列表 , 这些GONOPROXY前缀是私有的,不应从任何代理请求 。例如:
Go语言编译器TinyGo,基于LLVM,在微控制器和小系统上编译和运行 TinyGo是一个为微控制器、WebAssembly(Wasm)和命令行工具等小型场景设计的Go语言编译器 。TinyGo重用了Go语言工具和LLVM使用的库,以编译用Go语言编写的程序 。目前,该项目在GitHub上已经积累了10.1k的Star 。
如下为一个示例程序 , 当运行在任何支持的带板载LED的主板上时,则会点亮内置LED 。
上述程序可以在单片机、Adafruit ItsyBitsy M0微控制器或任何支持的带内置LED的板上进行编译和不需要修改的运行,只要设置正确的TinyGo编译器目标即可 。例如,设置如下目标可以编译和点亮 单片机 。
项目概述
TinyGo项目旨在将Go语言引入到具有单进程或核心的微控制器和小系统 。TinyGo类似于emgo,但主要的区别在于作者想要保留Go内存模型 。另一个区别在于TinyGo在内部使用LLVM,因而可以获得更小更高效的代码以及更高的灵活性 。
创建TinyGo项目的初衷是,如果Python可以在微控制器上运行 , Go语言当然也应该能够在更低级微设备上运行 。
支持设备
你可以为微控制器、WebAssembly和Linux编译TinyGo程序 。目前,TinyGo支持以下85种微处理器板 。
更多技术细节请参阅原项目 。
Go语言版本控制及包依赖管理这个文件通过路径标识 rsc.io/hello 定义了一个模块,它本身还依赖于两个其他模块:golang.org/x/text 和 rsc.io/quote,这个模块自身编译的时候使用的是 go.mod 文件中指定的依赖列表的版本 。对于更上一层的编译,其他导入这个模块的地方将使用它较新的版本编译 。
包发布者最好使用语义化的 tag 发布版本,vgo 也鼓励通过打tag的版本号方式,而不是任意的提交版本 。
windows 怎么编译 go语言1、解压压缩包到go工作目录,如解压到E:\opensource\go\go,解压后的目录结构如下:
E:\opensource\go\go
├─api
├─bin
│├─go.exe
│├─godoc.exe
│└─gofmt.exe
├─doc
├─include
├─lib
├─misc
├─pkg
├─src
└─test
2、增加环境变量GOROOT,取值为上面的go工作目录
3、Path环境变量中添加";%GOROOT%\bin",以便能够直接调用go命令来编译go代码,至此go编译环境就配置好了
注:如果不想手动设置系统环境变量,也可下载go启动环境批处理附件 ,
修改goenv.bat文件中的GOROOT值为上面的go工作目录后直接双击该bat文件,go编译环境变量即设置完成 。
4、测试go编译环境,启动一个cmd窗口,直接输入go,看到下面的提示就是搭建成功了
E:\opensource\go\gogo
Go is a tool for managing Go source code.
Usage:
go command [arguments]
The commands are:
buildcompile packages and dependencies
cleanremove object files
docrun godoc on package sources
envprint Go environment information
fixrun go tool fix on packages
fmtrun gofmt on package sources
getdownload and install packages and dependencies
installcompile and install packages and dependencies
listlist packages
runcompile and run Go program
testtest packages
toolrun specified go tool
versionprint Go version
vetrun go tool vet on packages
Use "go help [command]" for more information about a command.
Additional help topics:
gopathGOPATH environment variable
packagesdescription of package lists
remoteremote import path syntax
testflagdescription of testing flags
testfuncdescription of testing functions
Use "go help [topic]" for more information about that topic.
5、编译helloworld测试程序,go语言包中test目录带有helloworld.go测试程序,源码见"附一 helloworld.go",
直接调用"go build helloworld.go"就生成了"helloworld.exe"可执行程序,运行一下这个程序看到了我们期望的hello,wolrd 。
E:\opensource\go\go\testgo build helloworld.go
E:\opensource\go\go\testhelloworld.exe
hello, world
E:\opensource\go\go\test
附一 helloworld.go
// cmpout
// Copyright 2009 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Test that we can do page 1 of the C book.
package main
func main() {
print("hello, world\n")
}
Go 是怎么使用 Go 来编译自身的是Go语言吗?
Go 编译过程 九个步骤
第一步. all.bash
% cd $GOROOT/src
% ./all.bash
第一步 all.bash 只是调用了另外两个 shell 脚本go语言编译模块:make.bash 和run.bash 。若使用 Windows 或 Plan9go语言编译模块,其过程也基本类似,只是脚本分别以 .bat 或 .rc 结尾 。在文章的其他部分,请用适当的操作系统对应的扩展来补全命令 。
第二步. make.bash
. ./make.bash --no-banner
【go语言编译模块 go语言编译过程】make.bash 作为 all.bash 内容的一部分,如果它退出也会中断构建过程
第三步. cmd/dist
gcc -O2 -Wall -Werror -ggdb -o cmd/dist/dist -Icmd/dist cmd/dist/*.c
当健全检查完成后,make.bash 开始编译 cmd/dist 。
第四步. go_bootstrap
现在 go_bootstrap 已经构建完成,make.bash 的最后一步是使用 go_bootstrap 编译完整的 Go 标准库,包括一个完整的 go 工具用以替换 。
echo "# Building packages and commands for $GOOS/$GOARCH."
"$GOTOOLDIR"/go_bootstrap install -gcflags "$GO_GCFLAGS" \
-ldflags "$GO_LDFLAGS" -v std
第五步. run.bash
现在 make.bash 已经完成,回到 all.bash 的执行,这会调用 run.bash 。run.bash 的任务是编译和测试标准库、运行时以及语言测试集 。
bash run.bash --no-rebuild
由于 make.bash 和 run.bash 都会调用 go install -a std,因此需要使用 –no-rebuild 标志来避免重复前面的步骤,–no-rebuild 跳过了第二个 go install 。
# allow all.bash to avoid double-build of everythingrebuild=trueif [ "$1" = "--no-rebuild" ]; then shiftelse echo '# Building packages and commands.' time go install -a -v std echofi
第六步. go test -a std
echo '# Testing packages.'
time go test std -short -timeout=$(expr 120 \* $timeout_scale)s
echo
接下来 run.bash 会在标准库里所有的包上来运行用 testing 包编写的单元测试 。由于 $GOPATH 和 $GOROOT 中有着相同的命名空间,所以不能直接使用 go test … 否则 $GOPATH 中的每个包也会被逐一测试,因此创建了一个用于标准库中的包的别名go语言编译模块:std 。由于一些测试需要比较长的时间,且会消耗大量内存,因此用 -short 标志对一些测试进行了过滤 。
第七步. runtime 和 cgo 测试
run.bash 接下来的部分会运行平台对 cgo 支持的测试 , 执行一些性能测试,并且编译一些伴随 Go 发行版一起的杂项程序 。随着时间的流逝,这些杂项程序的清单会越来越长,那么它们也就会不可避免的被从编译过程中悄悄剥离出去 。
第八步. go run test
(xcd ../test
unset GOMAXPROCS
time go run run.go
) || exit $?
run.bash 的倒数第二步会调用在 $GOROOT 下的 test 目录里的编译器和运行时的测试 。他们是对于编译器和运行时自身的,较为低级细节的测试 。会执行语言规格测试 , test/bugs 和 test/fixedbugs 子目录保存有那些已经被发现并被修复的问题的独立的测试 。驱动测试的是一个小 Go 程序 $GOROOT/test/run.go,会执行 test 目录里的每个 .go 文件 。一些 .go 文件的首行包含了指导 run.go 对结果作出判断的指令,例如,程序将会失败 , 或提供一个确定的输出队列 。
第九步. go tool api
echo '# Checking API compatibility.'
go tool api -c $GOROOT/api/go1.txt,$GOROOT/api/go1.1.txt \
-next $GOROOT/api/next.txt -except $GOROOT/api/except.txt
run.bash 的最后一步调用了 api 工具 。
go语言编译模块的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于go语言编译过程、go语言编译模块的信息别忘了在本站进行查找喔 。

    推荐阅读