【实践】gdb调试golang程序入门及gdb命令列表

笔名辉哥 · · 1252 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

1. 摘要

本文讲解gdb调试GOLANG程序的入门配置,以及gdb命令详解备忘。

2. gdb调试go程序入门

gdb是linux系统自带的调试器,功能十分强大,它不仅支持C/C++调试,也支持GO程序调试。

2.1 配置gdb

(1) 打开gdb初始化配置文件

vim ~/.gdbinit
(2) 增加一行,:wq!保存后退出
add-auto-load-safe-path /usr/local/go/src/runtime/runtime-gdb.py

2.2 编译golang

假设源码文件为main.go,查看循环进行了几次。

package main

import ( 
    "fmt" 
)

func main() { 
    for i := 0; i < 5; i++ {
        fmt.Println("looping %d times", i) 
    } 
    fmt.Println("Done") 
}

正常情况下编译运行的结果如下:

root@iZ2zeaij0rxu0p2muizoirZ:~/go/src/test# go run main.go
looping %d times 0
looping %d times 1
looping %d times 2
looping %d times 3
looping %d times 4
Done

虽然gdb也支持golang了,但是在编译golang仍然需要加一些特殊的参数,否则出现如下的错误:

No symbol  in current context

就是程序内的变量,你都无法打印,gdb说找不到。所以编译时,需要加下列的参数:

go build -gcflags "-N -l" main.go

2.3 gdb调试

使用gdb启动一个go程序:

root@iZ2zeaij0rxu0p2muizoirZ:~/go/src/test# gdb main
GNU gdb (Ubuntu 7.11.1-0ubuntu1~16.5) 7.11.1
Copyright (C) 2016 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-linux-gnu".
Type "show configuration" for configuration details.
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>.
Find the GDB manual and other documentation resources online at:
<http://www.gnu.org/software/gdb/documentation/>.
For help, type "help".
Type "apropos word" to search for commands related to "word"...
Reading symbols from main...done.
Loading Go Runtime support.
(gdb) 

其中,出现“Loading Go Runtime support "这句话,就表示gdb可以支持golang。”

2.3.1 打断点

在第9行打断点:

(gdb) b main.go:9
Breakpoint 1 at 0x486a97: file /root/go/src/test/main.go, line 9.

2.3.2 运行到断点

(gdb) run
Starting program: /root/go/src/test/main 
[New LWP 7260]
[New LWP 7261]
[New LWP 7262]
[New LWP 7263]

Thread 1 "main" hit Breakpoint 1, main.main () at /root/go/src/test/main.go:9
9           fmt.Println("looping %d times", i) 

2.3.3 查看当前的局部变量,继续运行到下一个断点

(gdb) p i
$1 = 0
(gdb) info locals
i = 0
(gdb) c
Continuing.
looping %d times 0

Thread 1 "main" hit Breakpoint 1, main.main () at /root/go/src/test/main.go:9
9           fmt.Println("looping %d times", i) 
(gdb) p i
$3 = 1

2.3.4 查看当前所有断点,取消断点

(gdb) info breakpoints
Num     Type           Disp Enb Address            What
1       breakpoint     keep y   0x0000000000486a97 in main.main at /root/go/src/test/main.go:9
    breakpoint already hit 2 times
(gdb) disable breakpoint 1

2.3.5 退出

(gdb) quit
root@iZ2zeaij0rxu0p2muizoirZ:~/go/src/test# 

3,GDB调试命令列表

(gdb) info breakpoints // 查看所有断点。

(gdb) r // 启动进程,触发第一个断点。

(gdb) info goroutines // 查看 goroutines 信息。

(gdb) goroutine 1 bt // 查看指定序号的 goroutine 调用堆栈

(gdb) c / / 继续执行,触发下一个断点。

(gdb) bt // 查看当前调⽤堆栈,可以与当前 goroutine 调用堆栈对比。

(gdb) info frame // 堆栈帧信息。

(gdb) info locals // 查看局部变量。

(gdb) p s // 以 Pretty-Print 方式查看变量。

(gdb) clear //清除所有设置在函数上的断点。

(gdb) help all //可以看到所有的命令

4. 参考

(1),调试Go程序
https://blog.csdn.net/wanchope/article/details/53367064

(2),gdb调试golang程序
https://blog.csdn.net/KentZhang_/article/details/84922427

(3),使用 gdb 工具调试 Go
https://www.oschina.net/translate/using-gdb-debugger-with-go

(4),GDB调试命令详解
https://blog.csdn.net/linux7985/article/details/52399439


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:笔名辉哥

查看原文:【实践】gdb调试golang程序入门及gdb命令列表

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1252 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传