注:以下内容中,圆括号表示别名,方括号表示可选参数,尖括号表示必须参数。
gdb [文件名]:进入调试
file <文件名>:加载程序
l(list) [行号或函数名]:列出代码
r(run):运行程序/重新运行程序
c(continue):继续执行
n(next):单步步过
s(step):单步步入
ni(nexti):指令级单步步过(用于汇编调试)
si(stepi):指令级单步步入(用于汇编调试)
b(break) <行号或函数名或地址>:下断点(后面参数为地址时的写法为 b *0x01010101)
p(print) <变量名>:打印变量的值
finish:执行当前函数代码直到函数返回
u(until) <行号>:一直执行到某一行
q(quit):退出
k(kill):停止被调试的程序
i r(info registers) [寄存器名]:查看寄存器的值
i b(info breakpoints):查看断点信息
display <变量>:每次中断都打印变量的值
display /[N]i $pc:每次中断都打印即将执行的N条汇编指令(默认情况下N=1)
x /[N]b <变量或地址>: 列出指定位置的N个字节的内存的内容(默认情况下N=1,后面参数为地址时的写法为 x /10b 0x01010101)
set dis intel:设置汇编语法为intel格式(即x86汇编,默认为AT&T汇编,新版gdb的写法为set disassembly-flavor intel)
disass <函数名>:反汇编main函数
set logging file <文件名>: 设置日志文件
set logging on:打开日志输出(gdb会把调试过程中的所有信息输出到设置的日志文件中)
set logging off:关闭日志输出

1万+

被折叠的 条评论
为什么被折叠?



