Golang在Debian中的调试技巧
Delve是Go语言的原生调试器,专为Go设计,支持断点、单步执行、变量查看/修改等功能,是Debian下调试Golang的首选工具。
go get -u github.com/go-delve/delve/cmd/dlv,自动下载并安装到$GOPATH/bin。dlv debug ./main.go(main.go为入口文件),进入交互式调试界面。break main.go:10:在main.go第10行设置断点;continue(或c):继续执行程序至下一个断点;next(或n):单步执行(不进入函数);step(或s):进入函数内部;print variable_name(或p):打印变量值;set variable_name = new_value:修改变量值;clear:删除当前断点;trace main.go:10:设置跟踪点(执行到该行时打印信息)。GDB是通用调试器,虽非Go专属,但可通过添加调试信息调试Golang程序,适合熟悉GDB的用户。
sudo apt-get install gdb,安装GDB工具。go build -gcflags "-N -l" -o debug-demo debug-demo.go,-N禁用优化,-l禁用内联,保留调试符号。gdb ./debug-demo,进入GDB界面后,使用break main.main(在main函数设置断点)、run(启动程序)、next(单步)、print variable_name(打印变量)等命令调试。通过VS Code或GoLand等IDE,可图形化调试Golang程序,提升效率。
launch.json:在项目根目录创建.vscode/launch.json,添加以下内容:{ "version": "0.2.0", "configurations": [ { "name": "Launch", "type": "go", "request": "launch", "mode": "auto", "program": "${workspaceFolder}", "env": {}, "args": [] } ] } main.go,点击行号左侧设置断点,按F5开始调试,使用调试工具栏控制执行流程。Shift+F10),进入调试模式,支持变量查看、函数进入/跳出等功能。通过标准库log或第三方日志库(如logrus)记录程序执行流程和变量值,辅助定位问题。
log包,在代码中添加log.Println("程序启动")、log.Printf("变量值:%v", variable),输出到标准输出;log.SetOutput(os.Stdout)设置输出目标(如文件),log.SetFlags(log.LstdFlags|log.Lshortfile)添加时间戳和文件名,便于追踪日志来源。使用pprof工具分析程序的CPU、内存使用情况,定位性能瓶颈。
_ "net/http/pprof",并启动HTTP服务:import _ "net/http/pprof" func main() { go func() { log.Println(http.ListenAndServe("localhost:6060", nil)) }() // 程序逻辑 } go tool pprof http://localhost:6060/debug/pprof/profile?seconds=30(采集30秒CPU数据);go tool pprof http://localhost:6060/debug/pprof/heap;top(查看占用最高的函数)、list 函数名(查看函数内代码耗时)、web(生成调用图)等命令。通过testing包编写单元测试,验证代码逻辑的正确性,快速定位函数级问题。
xxx_test.go文件,编写测试函数(以Test开头),例如:import "testing" func TestAdd(t *testing.T) { result := Add(1, 2) if result != 3 { t.Errorf("Add(1, 2) = %d; want 3", result) } } go test -v(-v显示详细输出),查看测试结果。