安装

  1. apt install gdb-minimal

使用

常用命令

  1. gdb调试一个正在运行中的进程attach
  2. gdb <program> PID
  3. 单步不过:n
  4. 单步步入:s
  5. 执行到函数retun返回:finish
  6. list: 列出当前位置之后的10行代码;
  7. list line_number: 列出line_number之后的十行代码
  8. 列出调用栈:btbacktrace
  9. 列出当前函数的局部变量:info locals
  10. 打印变量值:p var_
  11. 条件中断:breakif
  12. 设置断点:br
  13. br filename:line_num
  14. br namespace::classname::func_name
  15. 列出所有断点:info breakpoints
  16. 删除所有断点:delete breakpoints
  17. 删除编号为id的断点:delete breakpoints id
  18. 禁用/启用断点:disable/enable breakpoints id

列文件清单

list / l

列出产生执行文件的源代码的一部分

//列出 line1 到 line2 行之间的源代码
(gdb) list line1, line2

//输出从上次调用list命令开始往后的10行程序代码
(gdb) list

//输出第 n 行附近的10行程序代码
(gdb) list n

//输出函数function前后的10行程序代码
(gdb) list function

执行程序

run / r

运行准备调试的程序,在它后面可以跟随发给该程序的任何参数,包括标准输入和标准输出说明符(<和>)和shell通配符(*、?、[、])在内。
如果使用不带参数的run命令,gdb就再次使用给予前一条run命令的参数,这是很有用的。

set args

命令就可以修改发送给程序的参数,而使用

show args

命令就可以查看其缺省参数的列表:

  • (gdb) set args –b –x
  • (gdb) show args

    显示数据

    print / p

    查看变量的值

    //利用print 命令可以检查各个变量的值。
    (gdb) print p (p为变量名)

print 是 gdb 的一个功能很强的命令,利用它可以显示被调试的语言中任何有效的表达式。表达式除了包含你程序中的变量外,还可以包含以下内容:

//对程序中函数的调用
(gdb) print find_entry(1, 0)
//数据结构和其他复杂对象
(gdb) print *table_start
$8={e=reference=’\000’,location=0x0,next=0x0}

//值的历史成分
(gdb)print $1 ($1为历史记录变量,在以后可以直接引用 $1 的值)

whatis

查看变量的类型:

//whatis 命令可以显示某个变量的类型
(gdb) whatis p
type = int *

设置与清除断点

break / b

可以用来在调试的程序中设置断点,该命令有如下四种形式:

//使程序恰好在执行给定行之前停止
break line-number

//使程序恰好在进入指定的函数之前停止 break function-name

//如果condition(条件)是真,程序到达指定行或函数时停止
break line-or-function if condition

//在指定例程的入口处设置断点
break routine-name

如果该程序是由很多原文件构成的,你可以在各个原文件中设置断点,而不是在当前的原文件中设置断点,其方法如下:

(gdb) break filename:line-number (gdb) break filename:function-name

break if

设置一个条件断点:

(gdb) break line-or-function if expr (gdb) break 46 if testsize==100

clean number

清除原文件中某一代码行上的所有断点
number为原文件的某个代码行的行号

断点的管理

info break

显示当前gdb的断点信息:

delete breakpoint

delete 删除指定的某个断点:

//该命令将会删除编号为1的断点
(gdb) delete breakpoint 1

//如果不带编号参数,将删除所有的断点
(gdb) delete breakpoint

enable / disable breakpoint 1

启用 / 禁用使用某个断点
该命令将禁止、允许断点 1,同时断点信息的 (Enb)域将变为 n、y

单步执行

n(next)

不进入的单步执行

step

进入的单步执行

finish

如果已经进入了某函数,而想退出该函数返回到它的调用函数中,可使用命令finish

until

结束当前循环

函数的调用

call name

调用和执行一个函数

(gdb) call gen_and_sork( 1234,1,0 )
(gdb) call printf(“abcd”)
$1=4

finish 结束执行当前函数,显示其返回值(如果有的话)

原文件的搜索

search text

该命令可显示在当前文件中包含text串的下一行。

reverse-search text

该命令可以显示包含text 的前一行。

常用的gdb命令

backtrace / bt = 显示程序中的当前位置和表示如何到达当前位置的栈跟踪(同义词:where) breakpoint / b = 在程序中设置一个断点 cd = 改变当前工作目录 clear = 删除刚才停止处的断点 commands = 命中断点时,列出将要执行的命令 continue = 从断点开始继续执行 delete = 删除一个断点或监测点;也可与其他命令一起使用 display = 程序停止时显示变量和表达时 down = 下移栈帧,使得另一个函数成为当前函数 frame = 选择下一条continue命令的帧 info = 显示与该程序有关的各种信息 jump = 在源程序中的另一点开始运行 kill = 异常终止在gdb = 控制下运行的程序 list = 列出相应于正在执行的程序的原文件内容 next = 执行下一个源程序行,从而执行其整体中的一个函数 print = 显示变量或表达式的值 pwd = 显示当前工作目录 ptype = 显示一个数据结构(如一个结构或C++类)的内容 quit = 退出gdb reverse-search = 在源文件中反向搜索正规表达式 run = 执行该程序 search = 在源文件中搜索正规表达式 set variable = 给变量赋值 signal = 将一个信号发送到正在运行的进程 step = 执行下一个源程序行,必要时进入下一个函数 undisplay / display = 命令的反命令,不要显示表达式 until = 结束当前循环 up = 上移栈帧,使另一函数成为当前函数 watch = 在程序中设置一个监测点(即数据断点) whatis = 显示变量或函数类型

GDB调试器的详细使用介绍