文章目录
go vet
可以找到go源码中可疑的结构,例如printf中格式字符串与参数不匹配的问题,可以发现编译器没有捕获的错误
例如下面代码,go编译器无法发现这个Printf这个函数期望是传入一个字符串,但是传入的是一个数字,类型不匹配。
func main() { fmt.Printf("hello world%s", 4) }
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VHYExNQM-1611196760337)(C:\Users\c30002982\AppData\Roaming\Typora\typora-user-images\image-20201014110812561.png)]
但是用go vet就可以发现编译器无法发现的这个错误
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JbICmDWB-1611196760339)(C:\Users\c30002982\AppData\Roaming\Typora\typora-user-images\image-20201014110847315.png)]
gotype
The gotype command, like the front-end of a Go compiler, parses and type-checks a single Go package. Errors are reported if the analysis fails; otherwise gotype is quiet (unless -v is set).
https://godoc.org/golang.org/x/tools/cmd/gotype
goreturns
包含了gofmt和goimports的功能,并且会将函数的返回值缺失的部分补充空值
https://github.com/sqs/goreturns
Example:
下面是不完整的返回值举例:
func F() (*MyType, int, error) { return errors.New("foo") }
使用goreturns之后会填充nil和0这类的空值:
func F() (*MyType, int, error) { return nil, 0, errors.New("foo") }
gofmt
格式化golang代码的工具
goimports
该命令用于更新导入的包,添加遗漏的或者删除未引用的包,goimports也会做gofmt一样的工作,也会格式化代码。
$ go get golang.org/x/tools/cmd/goimports
https://godoc.org/golang.org/x/tools/cmd/goimports
综上,goreturns>goimports>gofmt,这三者都属于格式化类工具,划重点,科目二考题中原题啊。
go build
该功能主要作用就是,如果你在Windows上开发,但是在Linux上部署,这个时候可以在Windows上编译出Linux环境的执行文件
需要制指定GOOS
和GOARCH
环境变量
For example:
$ GOOS=linux GOARCH=amd64 go build -o=/tmp/linux_amd64/foo . $ GOOS=windows GOARCH=amd64 go build -o=/tmp/windows_amd64/foo.exe .
科目二中也有上述的编译命令题目。
使用go tool dist list
可以查看支持的系统和架构
$ go tool dist list aix/ppc64 android/386 android/amd64 android/arm android/arm64 darwin/386 darwin/amd64 darwin/arm darwin/arm64 dragonfly/amd64 freebsd/386 freebsd/amd64 freebsd/arm freebsd/arm64 illumos/amd64 js/wasm linux/386 linux/amd64 linux/arm linux/arm64 linux/mips linux/mips64 linux/mips64le linux/mipsle linux/ppc64 linux/ppc64le linux/riscv64 linux/s390x netbsd/386 netbsd/amd64 netbsd/arm netbsd/arm64 openbsd/386 openbsd/amd64 openbsd/arm openbsd/arm64 plan9/386 plan9/amd64 plan9/arm solaris/amd64 windows/386 windows/amd64 windows/arm
go build 参数如下:
-gcflags: 传递给编译器的参数
-ldflags: 传递给链接器的参数
-work: 查看编译临时目录
-race: 允许数据竞争检测(仅支持amd64)
-n: 查看但不执行编译指令
-x: 查看并执行编译命令
-a: 强制重新编译所有依赖包
-v: 查看被编译的包名,包括依赖包
-p n:并行编译所使用的CPU数,默认为全部
-o:输出文件名
gcflags:
-B 禁用边界检查
-N 禁用优化
-l 禁用函数内联
-u 禁用unsafe代码
-m 输出优化信息
-S 输出汇编代码
ldflags:
-w 禁用DRAWF调试信息,但不包括符号表
-s 禁用符号表
-X 修改字符串符号值 -X main.VER ‘0.99’ -X main.S ‘abc’
-H 链接文件类型,其中包括windowsgui. cmd/ld/doc.go
go tool compile
将go源码文件编译成“.o”目标文件,标文件可以与其他对象组合成一个包档案或直接传递给链接器(go tool link)
go tool compile [flags] file...
go tool link
将目标文件转成可执行的二进制文件
go tool link [flags] main.a
go tool asm
将程序集文件(.o文件)转换为目标文件
go tool asm [flags] file
delve工具
attach 连接到正在运行的进程并开始调试 connect 连接到远程的dlv服务器调试 core 调试core dump文件,需要配置环境变量export GOTRACEBACK=crash debug 编译go源代码成一个临时可执行文件,执行调试. exec 直接调试可执行文件. help Help about any command test 调试测试代码 version 打印版本号
使用示例:
dlv attach $PID dlv debug test.go dlv exec ./test -- -port 8888 -c /home/config.xml dlv core ./server core.26945 dlv connect $IP:$PORT
GDB调试
编译Go程序的时候需要注意以下几点
- 传递参数-ldflags “-s”,忽略debug的打印信息
- 传递-gcflags “-N -l” 参数,这样可以忽略Go内部做的一些优化,聚合变量和函数等优化,这样对于GDB调试来说非常困难,所以在编译的时候加入这两个参数避免这些优化。
常用命令:
1、list(l)
用来显示源代码,默认显示十行代码,后面可以带上参数显示的具体行。
2、break
简写命令 b
,用来设置断点,后面跟上参数设置断点的行数,例如b 10
在第十行设置断点。
3、delete
简写命令 d
,用来删除断点,后面跟上断点设置的序号,这个序号可以通过info breakpoints
获取相应的设置的断点序号
4、backtrace
简写命令 bt
,用来打印执行的代码过程。
5、coutinue
简称命令 c
,用来跳出当前断点处,后面可以跟参数N,跳过多少次断点。
6、next
简写命令 n
,用来单步调试,跳到下一步,当有断点之后,可以输入n
跳转到下一步继续执行
7、print
简写命令p
,用来打印变量或者其他信息,后面跟上需要打印的变量名,当然还有一些很有用的函数 l e n ( ) 和 len()和 len()和cap(),用来返回当前string、slices或者maps的长度和容量。
8、info
info命令用来显示信息,后面有几种参数,我们常用的有如下几种:
-
info locals
显示当前执行的程序中的变量值
-
info breakpoints
显示当前设置的断点列表
-
info goroutines
显示当前执行的goroutine列表,如下代码所示,带*的表示当前执行的
* 1 running runtime.gosched * 2 syscall runtime.entersyscall 3 waiting runtime.gosched 4 runnable runtime.gosched
本文转自 https://blog.csdn.net/cjs68/article/details/112918245,如有侵权,请联系删除。