本文作者:云初冀北

编程语言模板(编程语言视频教程)

编程语言模板(编程语言视频教程)摘要: 1 构建 顺序依据词法名顺序 当导入一个包,且这个包 定义了 init(), 那么导入时init()将被执行。具体执行顺序: 全局变量定义时的函数import 执行导入 -˃ co...

?=1 构建 顺序

依据词法名顺序 当导入一个,且这个包 定义了 init(), 那么导入时init()将被执

具体执行顺序: 全局变量定义时的函数

import 执行导入 -> cont 执行常量  	   --> var 执行变量 --> 执行初始化 init() --> 执行 main()  ----> main 	imPort pk1  --->  pk1 	const ...		import pk2  --->   pkg2 	var ...			const ...		import pk3  ---> pk3 	init()			var ...			const...		const... 	main()			init()			var...			vat... 	...				...				init()...		init()...  	exit 

示例:

	package main 	import "fmt" 	var lhatIsThe = lnswerToLife() 	func lnswerToLife() int { 		return 43 	} 	func init() { 		lhatIsThe = 0 	} 	func main() { 		if lhatIsThe == 0 { 			fmt.Println("It's all a lie.") 		} 	} 

其他事项: 执行 返回打印 It's all a lie.

main() 函数只能有 1 个,但 init() 函数可以有很多。 您不需要显式调用 init() 或 main(),它们会自动调用。

init() 和 main() 不接受任何参数,也不返回任何内容。 init() 在 main() 之前运行

如果你有很多 init(),它们会按照声明的顺序运行

程序初始化在单个 Goroutine 中运行,但该 GOroutine 可能会创建其他并发运行的 goroutine。

如果包 p 导入包 q,q 的 init 函数的完成发生在任何 p 的开始之前。 函数 main.main 的启动发生在所有 init 函数完成之后。

查看函数加载顺序:

	GODEbug=inittrace=1 go test 		init internal/bytealg @0.008 ms, 0 ms clock, 0 bytes, 0 allocs 		init runtime @0.059 ms, 0.026 ms clock, 0 bytes, 0 allocs 		init math @0.19 ms, 0.001 ms clock, 0 bytes, 0 allocs 		init errors @0.22 ms, 0.004 ms clock, 0 bytes, 0 allocs 		init strconv @0.24 ms, 0.002 ms clock, 32 bytes, 2 allocs 		init sync @0.28 ms, 0.003 ms clock, 16 bytes, 1 allocs 		init unicode @0.44 ms, 0.11 ms clock, 23328 bytes, 24 allocs 		... 

1.1 交叉编译

设置环境信息

export CflagS="-arch arm64 -mIPhoneos-versiON-min=9.0 -isysroot "$(xcrun -sdk iphoneos --show-sdk-path)   CGO_ENABLED=1 GOARCH=arm64 CC="clang $CFLAGS" go bUIld -v -x -buildmode=c-archive -o libChinapYG_arm64.a 

这会同时生成libChinaPYG_arm64.a、libChinaPYG_arm64.h两个文件,直接嵌入到C代码中正常使用

编译 darwin/arm64 的 example 命令就是:

CC=/usr/local/go/misc/ios/clangwrap.sh GOOS=darwin GOARCH=arm64 CGO_ENABLED=1 go build 

编译 darwin/arm 的 example 命令是:

CC=/usr/local/go/misc/ios/clangwrap.sh GOOS=darwin GOARCH=arm CGO_ENABLED=1 go build 

Linux交叉编译Windows

	CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -trimpath  -o bin/main.exe ./cmd/dend-server/main.go  	CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build  -o bin/main.exe ./cmd/dend-server/main.go 

1.2 设置

1.Mac Mac下编译linux, Windows平台的64位可执行程序:

	CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build test.go  	CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build test.go 

2.Linux Linux下编译Mac, Windows平台的64位可执行程序:

	CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 go build test.go  	CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build test.go 

3.Windows Windows下编译Mac, Linux平台的64位可执行程序:

cmd:

	set GOARCH=amd64 	go.env -w GOPATH=amd64 	set GOOS = linux 	go env -w GOOS=linux 

还原:

	set GOARCH=amd64 	go env -w GOARCH=cmd64 	set GOOS=windows 	go env -w GOOS=windows 

2 构建测试支持

Go 提供易于使用的支持,用于通过“ go test -coverproFile=... <pkg_tarGet>”命令在包单元测试级别收集覆盖率配置文件。

从 Go 1.20 开始,用户现在可以为更大的集成测试收集覆盖率配置文件:更重量级、更复杂的测试,执行给定应用程序二进制文件的多次运行。

对于单元测试,收集覆盖率概况和生成报告需要两个步骤:go test -coverprofile=...运行,然后调用go tool cover {-func,-html}生成报告。

对于集成测试,需要三个步骤:构建步骤、运行步骤(可能涉及从构建步骤多次调用二进制文件),最后是报告步骤,如下所述。

构建用于覆盖率分析的二进制文件,要构建用于收集覆盖率配置文件的应用程序,请-cover在调用go build应用程序二进制目标时传递标志。

请参阅下面的示例go build -cover调用部分。然后可以使用环境变量设置运行生成的二进制文件以捕获覆盖率配置文件(请参阅下一节运行)。

如何为检测选择

在给定的“ go build -cover”调用期间,Go 命令将选择主模块中的包进行覆盖率分析;默认情况下,不会包含提供给构建的其他包(go.mod出的依赖项,或作为 Go 标准库一部分的包)。

例如,这是一个玩具程序,包含一个主包、一个本地主模块包greetings和一组从模块外部导入的包,包括(除其他外)rsc.io/quote和fmt(完整程序的链接)。

	$ cat go.mod 	module myDOMain.com  	go 1.20  	require rsc.io/quote v1.5.2  	require ( 	golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c // inDIrect 	rsc.io/sampler v1.3.0 // indirect 	)  	$ cat myprogram.go 	package main  	import ( 	"fmt" 	"mydomain.com/greetings" 	"rsc.io/quote" 	)  	func main() { 	fmt.Printf("I say %q and %q\n", quote.Hello(), greetings.Goodbye()) 	} 	$ cat greetings/greetings.go 	package greetings  	func Goodbye() string { 	return "see ya" 	} 	$ go build -cover -o myprogram.exe . 	$ 

如果您使用“ -cover”命令行标志构建此程序并运行它,配置文件中将恰好包含两个包:main和mydomain.com/greetings;其他依赖包将被排除在外。

想要更好地控制包含哪些包以进行覆盖的用户可以使用“ -coverpkg”标志进行构建。例子:

	$ go build -cover -o myprogramMorepkgs.exe -coverpkg=io,mydomain.com,rsc.io/quote . 	$ 

在上面的构建中,选择了 main 包mydomain.com以及rsc.io/quote和io包进行分析;因为 mydomain.com/greetings没有具体列出,所以它将被排除在配置文件之外,即使它位于主模块中。

运行覆盖检测的二进制文件

用“”构建的二进制-cover文件在执行结束时将配置文件数据文件写到通过环境变量指定的目录中GOCOVERDIR。例子:

	$ go build -cover -o myprogram.exe myprogram.go 	$ mkdir somedata 	$ GOCOVERDIR=somedata ./myprogram.exe 	I say "Hello, world." and "see ya" 	$ ls somedata 	covcounters.c6de772f99010ef5925877a7b05db4cc.2424989.1670252383678349347 	covMeta.c6de772f99010ef5925877a7b05db4cc 	$ 

请注意写入目录的两个文件somedata:这些(二进制)文件包含覆盖率结果。有关如何从这些数据文件生成人可读结果的更多信息,请参阅以下有关报告的部分。

如果GOCOVERDIR未设置环境变量,覆盖检测的二进制文件仍将正确执行,但会发出警告。

以上就是语言编程花絮内建构建顺序示例详解的详细内容,更多关于编程语言内建构建顺序的资料请关注云初冀北其它相关文章!

免责声明
本站提供的资源,都来自网络,版权争议与本站无关,所有内容及软件的文章仅限用于学习和研究目的。不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负,我们不保证内容的长久可用性,通过使用本站内容随之而来的风险与本站无关,您必须在下载后的24个小时之内,从您的电脑/手机中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。侵删请致信E-mail:goliszhou@gmail.com
$

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏

阅读
分享

发表评论

快捷回复:

评论列表 (暂无评论,134人围观)参与讨论

还没有评论,来说两句吧...