一、gdb基本使用
GDB是一个由GNU开源组织发布的、UNIX/LINUX操作系统下的、基于命令行的、功能强大的程序调试工具。 对于一名Linux下工作的c++程序员,gdb是必不可少的工具;
1. 启动gdb
对于C/C++程序,编译的时候需要加上 -g
参数生成调试信息。如:gcc -g hello.c -o hello
调试可执行程序
$gdb 程序名称
$gdb ./hello # 调试当前目录下名称为hello的程序
调试服务程序
$gdb 程序名称 进程pid
$gdb hello 5678 # 调试当前目录下名称为hello,进程pid为5678的程序
调试core文件(程序崩溃后生成的core dump 文件)
$gdb 程序名称 core文件名称
$gdb hello core.0609 # 调试当前目录下名称为hello,core文件名称为core.0609的程序
2. gdb交互式命令
启动gdb后,进入到交互模式,通过以下命令完成对程序的调试;高频使用的命令一般都会有缩写,熟练使用这些缩写命令能提高调试的效率;
运行
run:缩写为 r
,运行程序,当遇到断点后停止,程序会在断点处停止运行,等待用户输入下一步的命令,类似于vs中的 F5。continue: 缩写为 c
,继续执行,到下一个断点(没有断点就运行到程序结束)。step: 缩写为 s
,单步调试如果遇到函数则进入函数;与命令n
不同,n是不尽然调用的函数的,step 相当于vs的 F11。next:缩写为 n
,单步跟踪程序,当遇到调用函数时不进入函数;此命令与step的主要区别是,step 遇到用户自定义的函数,进步入到函数中运行,而 next 则是直接调用函数,不会进入到函数内,next 相当于vs的 F10。until
: 当进入到循环中时,使用until命令可以使程序直接运行到退出循环体。until+行号
:运行至指定行,不仅仅用来跳出循环。finish
: 运行程序,知道当前函数返回,并打印函数返回时的堆栈地址和返回值及参数值等信息。call 函数(参数)
: 调用程序中的函数,并传递“参数”,如:call add(3,2)
quit: 缩写为q
,退出gdb。
设置断点
gdb使用break(缩写为 b)
来设置断点,具体使用如下:
break n
(简写 b n),在第 n 行处设置断点(可以写上代码路径和文件名称,如b ./test.cpp:10
)b fn1 if a>b
,设置条件断点。b func
,在函数func()入口处设置断点。info b (info breakpoints)
显示当前程序的断点设置情况和断点的断点号等信息。disable 断点号n
, 禁用第n个断点。enable 断点号n
,启用第n个断点。delete 断点号n
,删除第n个断点。delete breakpoints
,清除所有断点。
查看源代码
list 简记为 l
: 列出程序的源代码,默认每次显示10行。list 行号
:将显示当前文件以“行号”为中心的前后10行代码,如:list 12list 函数名
:将显示“函数名”所在函数的源代码,如:list mainlist
:不带参数,将接着上一次 list 命令的,输出下边的内容。
打印表达式
print 表达式
:简记为 p ,其中“表达式”可以是任何当前正在被测试程序的有效表达式,比如当前正在调试C语言的程序,那么“表达式”可以是任何C语言的有效表达式,包括数字,变量甚至是函数调用。print a
:将显示整数 a 的值print ++a
:将把 a 中的值加1,并显示出来print name
:将显示字符串 name 的值print gdb_test(22)
:将以整数22作为参数调用 gdb_test() 函数print gdb_test(a)
:将以变量 a 作为参数调用 gdb_test() 函数display 表达式
:在单步运行时将非常有用,使用display命令设置一个表达式后,它将在每次单步进行指令后,紧接着输出被设置的表达式及值。如:display a
watch 表达式
:设置一个监视点,一旦被监视的“表达式”的值改变,gdb将强行终止正在被调试的程序。如:watch a
whatis
:查询变量或函数info function
: 查询函数扩展info locals
: 显示当前堆栈页的所有变量
查询查询运行信息
where/bt
:当前运行的堆栈列表;bt backtrace
显示当前调用堆栈up/down
改变堆栈显示的深度set args
参数:指定运行时的参数show args
:查看设置好的参数info program
: 来查看程序的是否在运行,进程号,被暂停的原因。
分割窗口
layout
:用于分割窗口,可以一边查看代码,一边测试:layout src
:显示源代码窗口layout asm
:显示反汇编窗口layout regs
:显示源代码/反汇编和CPU寄存器窗口layout split
:显示源代码和反汇编窗口Ctrl + L
:刷新窗口