Go官方团队在2022.06.11发布了Go 1.19 Beta 1版本,Go 1.19的正式release版本预计会在今年8月份发布。
让我们先睹为快,看看Go 1.19给我们带来了哪些变化。
这是Go 1.19版本更新内容详解的第2篇,欢迎大家关注公众号,及时获取本系列最新更新。
和Go 1.18相比,改动相对较小,主要涉及语言(Language)、内存模型(Memory Model)、可移植性(Ports)、Go Tool工具链、运行时(Runtime)、编译器(Compiler)、汇编器(Assembler)、链接器(Linker)和核心库(Core library)等方面的优化。
第1篇详细介绍了Go 1.19在语言、内存模型、可移植性方面的改进。
本文重点介绍Go 1.19版本在Go Tool工具链方面的变化。
文档注释(doc comments) 是Go语言里的对包(package), 常量(const), 函数(func), 类型(type)和变量(var)声明的一种注释规范。按照这个规范来注释,就可以使用go doc
命令生成对应的代码说明文档。
像大家熟知的https://pkg.go.dev/里的说明文档就是通过编写符合doc comments规范的文档注释来生成的。
Go 1.19 在文档注释里新增了对于链接、列表和更清晰的标题的支持,可以参考“Go Doc Comments” 了解语法细节。
作为这个修改的一部分,gofmt
现在会把文档注释重新格式化,让文档展示的样式更清晰。
同时,新增了一个package: go/doc/comment,可以用于解析和重新格式化文档注释,并且支持把文档注释渲染为HTML, Markdown和text格式。
Go语言支持使用编译约束(build constraint)进行条件编译。Go 1.19版本新增了编译约束 unix
,可以在//go:build
后面使用unix
。
//go:build unix
unix
表示编译的目标操作系统是Unix或者类Unix系统。对于Go 1.19版本而言,如果GOOS
是 aix
, android
, darwin
, dragonfly
, freebsd
, hurd
, illumos
, ios
, linux
, netbsd
, openbsd
, 或 solaris
中的某一个,那就满足unix
这个编译约束。
未来unix
约束还会匹配一些新的类Unix操作系统。
go build
如果使用-trimpath
标记,会在生成的可执行文件里打上trimpath
标签,我们可以使用 go
version
-m
或debug.ReadBuildInfo
检查可执行文件是否是使用-trimpath
标记编译生成的。
备注:编译的时候带上trimpath
标记可以去除Go程序运行时打印的堆栈信息里包含的Go程序的编译路径和编译机用户信息,避免信息泄露。
go
generate
现在会在生成器环境里设置 GOROOT
环境变量,所以即使使用了-trimpath
进行编译,生成器也可以精准定位到GOROOT
的路径。
go
test
和 go
generate
运行时会把 GOROOT/bin
放在 PATH
环境变量的开头,这样设计后,go test
和go generate
执行的时候可以解析到同一个GOROOT
。解决的是这个GitHub Issue。
go
env
会把环境变量的值中带有空格的加上双引号括起来,包括CGO_CFLAGS
, CGO_CPPFLAGS
, CGO_CXXFLAGS
, CGO_FFLAGS
, CGO_LDFLAGS
, and GOGCCFLAGS
这些环境变量。解决的是Windows环境下不带空格会报错的bug,详情可以参考GitHub Issue。
CGO_CFLAGS="-g -O2"
CGO_CPPFLAGS=""
CGO_CXXFLAGS="-g -O2"
CGO_FFLAGS="-g -O2"
CGO_LDFLAGS="-g -O2"
PKG_CONFIG="pkg-config"
GOGCCFLAGS="-fPIC -arch x86_64 -m64 -pthread -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -fdebug-prefix-map=/var/folders/pv/_x849j6n22x37xxd9cstgwkr0000gn/T/go-build4165054210=/tmp/go-build -gno-record-gcc-switches -fno-common"
go
命令现在会缓存必要的信息用于加载模块(module),这会带来go list
调用的加速。
对-trimpath
和go generate
不了解的,推荐阅读官方文档:
go vet
新增了一个errorsas
检查规则,可以对errors.As
函数调用进行正确性检查。
如果errors.As
的第2个参数是*error
类型,go vet
会提示错误,这也是大家使用errors.As
常犯的一个错误。
Go 1.19版本变更内容第1篇,第1篇主要涉及到Go泛型的细小改动以及Go内存模型和原子操作的优化。
想了解Go泛型的使用方法、设计思路和最佳实践,推荐大家阅读:
想了解Go原子操作和使用方法,推荐大家阅读:
下一篇会介绍Go 1.19在运行时、编译器、汇编器、链接器和核心库的优化工作,有一些内容值得学习,欢迎大家保持关注。
文章和示例代码开源在GitHub: Go语言初级、中级和高级教程。
公众号:coding进阶。关注公众号可以获取最新Go面试题和技术栈。
个人网站:Jincheng's Blog。
知乎:无忌。
我为大家整理了一份后端开发学习资料礼包,包含编程语言入门到进阶知识(Go、C++、Python)、后端开发技术栈、面试题等。
关注公众号「coding进阶」,发送消息 backend 领取资料礼包,这份资料会不定期更新,加入我觉得有价值的资料。还可以发送消息「进群」,和同行一起交流学习,答疑解惑。