GDB调试笔记

GDB是在Linux命令行下对C/C++的程序进行调试常用的一个命令, 现将平时记录在本子上的笔记整理记录一下.

一、断点

断点类型有breakpoints, watchpoints, catchpoints.

普通断点,程序运行到该点时暂停(此时此行尚未运行),是gdb中最常用的断点,相关命令为:

break [函数名,行数或者指令地址] [condi]

在指定地方加上断点 例:

(gdb) set $counter = 0
(gdb) break 26 if ++$counter == 99

在第26行设置断点,每次触发断点的时候执行判断条件,仅在判断条件为真的时候使程序在断点处停止。在循环的debug中很好用。 类似的命令还有condition等。 rbreak RE:
在所有符合正则表达式RE的函数上加上断点

也称为data breakpoints,在表达式值变化时停止执行的断点。

watch expr[thread threadnum]
表达式可以是变量值,地址(如*(int *)0x12345678)或数学表达式。

程序事件断点,如c++异常

catch event   :event可以是 throw或catch事件

查看断点:

info breakpoint[n]  打印所有(或者第n个)断点信息,同 info break info watchpoints[n]  : 同上

删除断点:

delete [断点号] [range…]  :range是断点号,空格分割

clear location   :location是函数名,行数等

enable/disable  :使能/使失效断点,不删除

其他

为断点号bnum写一个命令列表,程序运行到断点时gdb会依次运行列表中的命令:

commands [bnums]   …command list… end

二、单步调试

*step:*运行下一步(即step into,进入调用的函数体内) *next:*同上,但是不进入函数体 *finish:*往下运行直至当前栈帧(下面解释)中的函数返回 *continue:*往下运行直至遇到断点

打印信息:

print/x data: 以x(十六进制)格式打印数据data的值(或者缩写为p/x data); 输出格式有x、d、u、o、t(二进制,two,因为b已经用来表示byte)、a(address)、c(char)、f(float)、s(string)、r(raw)     

查看数据类型: ptype data;

打印数组: p *array@len

    

stack frame 是在栈中为参数、返回地址和局部变量保留的一块内存区,必要时在过程调用中使用,相关命令:

frame[args]: 从一个栈帧移动到另一个,并打印选择的栈帧。args可以是栈帧号或其地址。 info frame []: 查看栈帧的详细信息 backtrace: 向后追踪栈帧(调用)

##3)底层信息:

**查看汇编:**disassemble [option] [range]

接收一个参数时,打印该地址周围的函数的汇编,接收两个参数时,表示需要dump的范围

**查看内存:**x /nfu addr

n:重复数。默认为1,表示要显示多少内存(以单元u为基数)

f:显示格式。同print,默认为x, i表示机器指令

u:单元大小。分别可以是b(byte)、h(halfwords,=2byte)、w(words,=4byte)和g(gaint words,=8byte);默认为w

  寄存器:

$pc:程序计数器,值为下一条指令的地址

$ps:程序状态寄存器

$sp:stack pointer栈指针

$fp:frame pointer 指向当前栈帧的指针

三、变更执行

print i=num,赋值并打印变量i set i=num,仅赋值

  用’{…}‘结构来生成地址。如:

set {int}0x83040 = 4;  //将4存储到地址0x83040中

jump [location]

location可以是行号或者地址。注意jump命令仅仅改变$pc的值,而不改变当前栈帧、堆栈指针或上下文,效果相当于set $pc = {int}location

signal sig 立即将信号sig发给程序

return:使(函数)返回