你是使用什么工具调试 golang 程序的?
创始人
2024-05-31 13:50:20
0

写过 C/C++ 的都是到,调试程序的时候通常使用 gdb 工具来进行调试,用起来可爽了,那么 gdb 是否也适合 golang 程序的调试的

我个人到是通常使用 dlv 来进行 golang 程序的调试,分享一波

dlv 是什么,全称 Delve

Delve 可以让你通过控制程序的执行来与程序进行交互,他可以计算变量,并提供线程 / goroutine 状态、CPU 寄存器状态等信息

Delve 的目标是为调试 Go 程序提供一个简单强大的调试功能

尝试看一下 dlv 的 help 信息

image-20211029105238415

Usage:dlv [command]Available Commands:attach      Attach to running process and begin debugging.connect     Connect to a headless debug server.core        Examine a core dump.dap         [EXPERIMENTAL] Starts a headless TCP server communicating via Debug Adaptor Protocol (DAP).debug       Compile and begin debugging main package in current directory, or the package specified.exec        Execute a precompiled binary, and begin a debug session.help        Help about any commandrun         Deprecated command. Use 'debug' instead.test        Compile test binary and begin debugging program.trace       Compile and begin tracing program.version     Prints version.

通过 help 我们可以看到可以使用这些命令来调试我们的程序,根据不同的应用场景

例如,

我们直接编译并调试的时候就可以使用 dlv debug

调试一个正在运行的程序,就可以使用 dlv attach

调试一个编译好的二进制文件,可以使用 dlv exec

其他的使用方式也类似,看上述的英文大概就知道啥意思了

开始调试小程序

简单写一个小程序来应用一下这个调试工具

const NUM = 10func main() {arr := make([]int, NUM)for i := 1; i < NUM; i++ {arr[i] = i + ifmt.Printf("arr[%d] == %d\n", i, arr[i])}fmt.Println("program over")
}

1、使用 dlv debug main.go 开始调试

>dlv debug main.go
Type 'help' for list of commands.
(dlv)

2、dlv 里面使用 help 查看一下可以使用哪些命令

这些命令对应的解释相对还是比较清楚的,我们可以来用一下

3、使用 break 打给 main 函数一个端点,或者是用 b

(dlv) b main.main
Breakpoint 1 set at 0xef84ea for main.main() d:/mycode/my_new_first/dlvtest/main.go:7

给 main 函数打 1 断点,断点号是 1

4、continue 继续执行代码,直到运行到 main 的中断

(dlv) c
> main.main() d:/mycode/my_new_first/dlvtest/main.go:7 (hits goroutine(1):1 total:1) (PC: 0xef84ea)2: 3: import "fmt"4: 5: const NUM = 106: 
=>   7: func main() {8:         arr := make([]int, NUM)9: 10:         for i := 1; i < NUM; i++ {11:                 arr[i] = i + i12:                 fmt.Printf("arr[%d] == %d\n", i, arr[i])

5、再 打一个断点,加上具体的条件

  • b 文件:行数
  • condition 中断号 具体的条件
(dlv) b main.go:12
Breakpoint 2 set at 0xef85a4 for main.main() d:/mycode/my_new_first/dlvtest/main.go:12
(dlv) condition 2 i==7

6、continue 继续执行代码

(dlv) c
arr[1] == 2
arr[2] == 4
arr[3] == 6
arr[4] == 8
arr[5] == 10
arr[6] == 12
> main.main() d:/mycode/my_new_first/dlvtest/main.go:12 (hits goroutine(1):1 total:1) (PC: 0xef85a4)7: func main() {8:         arr := make([]int, NUM)9: 10:         for i := 1; i < NUM; i++ {11:                 arr[i] = i + i
=>  12:                 fmt.Printf("arr[%d] == %d\n", i, arr[i])13:         }14:         fmt.Println("program over")15: }

7、locals 查看本地变量信息 , p/print 打印变量信息

(dlv) locals
arr = []int len: 10, cap: 10, [...]
i = 7
(dlv) args
(no args)
(dlv) p i
7
(dlv) p arr
[]int len: 10, cap: 10, [0,2,4,6,8,10,12,14,0,0]
  • 使用 p 查看多个变量的信息,打印出具体的值

8、bp/breakpoints 查看中断列表 , clear 清空中断

  • 查看中断列表
  • 清空其中一个中断
  • 再查看中断列表看看效果
(dlv) bp
Breakpoint runtime-fatal-throw (enabled) at 0xe6ca00 for runtime.throw() c:/program files/go/src/runtime/panic.go:1107 (0)
Breakpoint unrecovered-panic (enabled) at 0xe6cc80 for runtime.fatalpanic() c:/program files/go/src/runtime/panic.go:1190 (0)print runtime.curg._panic.arg
Breakpoint 1 (enabled) at 0xef84ea for main.main() d:/mycode/my_new_first/dlvtest/main.go:7 (1)
Breakpoint 2 (enabled) at 0xef85a4 for main.main() d:/mycode/my_new_first/dlvtest/main.go:12 (1)cond i == 7
(dlv) clear 2
Breakpoint 2 cleared at 0xef85a4 for main.main() d:/mycode/my_new_first/dlvtest/main.go:12
(dlv) bp
Breakpoint runtime-fatal-throw (enabled) at 0xe6ca00 for runtime.throw() c:/program files/go/src/runtime/panic.go:1107 (0)
Breakpoint unrecovered-panic (enabled) at 0xe6cc80 for runtime.fatalpanic() c:/program files/go/src/runtime/panic.go:1190 (0)print runtime.curg._panic.arg
Breakpoint 1 (enabled) at 0xef84ea for main.main() d:/mycode/my_new_first/dlvtest/main.go:7 (1)

9、ls 查看当前代码运行的位置 ,next 执行源码的下一行

(dlv) ls
> main.main() d:/mycode/my_new_first/dlvtest/main.go:12 (hits total:0) (PC: 0xef85a4)7: func main() {8:         arr := make([]int, NUM)9: 10:         for i := 1; i < NUM; i++ {11:                 arr[i] = i + i
=>  12:                 fmt.Printf("arr[%d] == %d\n", i, arr[i])13:         }14:         fmt.Println("program over")15: }
(dlv) next
> main.main() d:/mycode/my_new_first/dlvtest/main.go:12 (hits total:0) (PC: 0xef85a4)7: func main() {8:         arr := make([]int, NUM)9: 10:         for i := 1; i < NUM; i++ {11:                 arr[i] = i + i12:                 fmt.Printf("arr[%d] == %d\n", i, arr[i])
=>  13:         }14:         fmt.Println("program over")15: }

通过箭头我们就可以看出来 ,没有毛病

10、bt/stack 打印堆栈信息

(dlv) bt
0  0x0000000000ef85a4 in main.mainat d:/mycode/my_new_first/dlvtest/main.go:12
1  0x0000000000e6f2f6 in runtime.mainat c:/program files/go/src/runtime/proc.go:225
2  0x0000000000e9f3a1 in runtime.goexitat c:/program files/go/src/runtime/asm_amd64.s:1371

查看堆栈信息,可以直接看到汇编里面的具体信息

11、goroutines 查看程序中的协程列表,以及其对应的代码行数

(dlv) goroutines
* Goroutine 1 - User: d:/mycode/my_new_first/dlvtest/main.go:12 main.main (0xef85a4) (thread 26592)Goroutine 2 - User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6) [force gc (idle)]Goroutine 3 - User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6) [GC sweep wait]Goroutine 4 - User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6) [GC scavenge wait]Goroutine 5 - User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6) [finalizer wait]
[5 goroutines]
(dlv) goroutine
Thread 26592 at d:/mycode/my_new_first/dlvtest/main.go:12
Goroutine 1:Runtime: d:/mycode/my_new_first/dlvtest/main.go:12 main.main (0xef85a4)User: d:/mycode/my_new_first/dlvtest/main.go:12 main.main (0xef85a4)Go: c:/program files/go/src/runtime/asm_amd64.s:226 runtime.rt0_go (0xe9d3cc)Start: c:/program files/go/src/runtime/proc.go:115 runtime.main (0xe6f0e0)

goroutine 执行的时候默认是查看当前协程的信息,上面打印可以知道,总共有 5 个协程,当前打印的协程信息是第 1 个

12、goroutine 显示当前当前协程的具体信息和切换协程

主动切换到 第 2 个协程,并查看当前协程的信息

(dlv) goroutine 2
Switched from 1 to 2 (thread 26592)
(dlv) goroutine
Thread 26592 at d:/mycode/my_new_first/dlvtest/main.go:12
Goroutine 2:Runtime: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6)User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6)Go: c:/program files/go/src/runtime/proc.go:264 runtime.init.6 (0xe6f47c)Start: c:/program files/go/src/runtime/proc.go:267 runtime.forcegchelper (0xe6f4a0)
(dlv) goroutinesGoroutine 1 - User: d:/mycode/my_new_first/dlvtest/main.go:12 main.main (0xef85a4) (thread 26592)
* Goroutine 2 - User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6) [force gc (idle)]Goroutine 3 - User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6) [GC sweep wait]Goroutine 4 - User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6) [GC scavenge wait]Goroutine 5 - User: c:/program files/go/src/runtime/proc.go:337 runtime.gopark (0xe6f6f6) [finalizer wait]
[5 goroutines]

工具需要用起来才有意义

好了,本次就到这里

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是阿兵云原生,欢迎点赞关注收藏,下次见~

相关内容

热门资讯

安卓免费私有云盘系统,探索安卓... 你有没有想过,你的手机里那些珍贵的照片、文件和视频,如果有一天突然丢失了,那该有多心疼啊!别担心,今...
安卓系统怎么装分身,安卓系统轻... 你是不是也和我一样,对安卓系统的分身功能充满了好奇?想要在手机上同时使用两个账号,但又不知道怎么操作...
安卓系统手机照片云恢复 手机里的照片丢失了,是不是瞬间感觉心情down到了谷底?别急,今天就来给你支个招,让你的安卓系统手机...
安卓系统的缓存怎么清,轻松优化... 手机用久了是不是感觉越来越卡?别急,今天就来教你怎么给安卓系统的缓存来个大扫除,让你的手机恢复活力!...
安卓4.4系统gps补丁 你知道吗?安卓4.4系统,也就是传说中的KitKat,可是智能手机界的一颗璀璨明珠呢!不过,就像所有...
安卓系统主界面设置,个性化与便... 你有没有发现,每次打开安卓手机,那主界面就像是个五彩斑斓的小天地?今天,就让我带你一起探索这个神奇的...
鼎桥是安卓系统吗,安卓系统背后... 你有没有听说过鼎桥这个品牌?最近它在手机市场上可是挺火的呢!不过,说到鼎桥,很多人都会好奇一个问题:...
红米note安卓7.0系统,畅... 你有没有发现,最近你的手机是不是有点儿不一样了?没错,就是那个陪伴你度过了无数日夜的红米Note,它...
安卓手机怎么安xp系统下载地址... 你有没有想过,把Windows XP这样的经典操作系统安装在安卓手机上?听起来是不是有点不可思议?但...
ios系统能转回安卓吗,iOS... 你有没有想过,手机系统之间的转换,就像是从一个熟悉的地方跳到另一个全新的世界呢?今天,我们就来聊聊这...
安卓系统怎么分屏聊天 你是不是也和我一样,手机里同时挂着好几个聊天窗口,一边和闺蜜聊着天,一边还得回复领导的邮件,感觉手忙...
苹果查安卓手机定位系统,安卓手... 你有没有想过,你的手机里藏着一个小秘密?没错,就是那个能让你随时随地找到它的神奇功能——定位系统。今...
安卓原生系统关闭锁定,轻松关闭... 你有没有发现,手机用久了,有时候安卓系统的锁定功能就像是个小顽皮,时不时地跳出来给你点小麻烦?别急,...
安卓系统的屏幕怎么调,安卓屏幕... 手机屏幕亮度总是调得刚刚好,是不是有点儿小烦恼呢?别急,今天就来手把手教你如何轻松调整安卓系统的屏幕...
光遇安卓系统崩了,官方紧急应对 最近光遇的安卓玩家们可真是有点头疼呢!你有没有发现,最近光遇安卓系统突然“崩了”,让不少玩家都陷入了...
安卓系统直播触摸大屏 你有没有想过,在安卓系统的世界里,直播和触摸大屏的结合能擦出怎样的火花呢?想象你正躺在沙发上,手捧着...
安卓系统映像预览版,前沿技术一... 你知道吗?最近安卓系统又出新花样了!这不,安卓系统映像预览版新鲜出炉,让我来带你一探究竟,看看这个新...
安卓系统如何防止死机,安卓系统... 手机突然卡顿,屏幕上那些图标就像被施了魔法一样,动也不动。你是不是也遇到过安卓系统死机的情况,心里那...
安卓系统手机自动播放,安卓手机... 你有没有发现,最近你的安卓手机是不是有点儿“调皮”呢?它总是在你最不想被打扰的时候,自动播放那些让你...
mini主机双系统安卓,轻松实... 你有没有想过,家里的电脑已经满足不了你的需求了?想要一台既能运行Windows系统,又能畅玩安卓应用...