GDB调试基本命令_Panix2n_n的博客-优快云博客_gdb调试命令
GDB常用命令
运行
run(简写r): 运行程序,当遇到断点后,程序会在断点处停止运行,等待用户输入下一步的命令。
continue(简写c):继续执行,到下一个断点处(或运行结束)
next(简写n): 单步跟踪程序,当遇到函数调用时,直接调用,不进入此函数体;
step(简写s):单步调试如果有函数调用,则进入函数;与命令n不同,n是不进入调用的函数的
until:运行程序直到退出循环体; / until+行号: 运行至某行
finish: 运行程序,直到当前函数完成返回,并打印函数返回时的堆栈地址和返回值及参数值等信息。
call 函数(参数):调用“函数”,并传递“参数”,如:call gdb_test(55)
quit:简记为 q ,退出gdb
设置断点
break n(简写b n):在第n行处设置断点 ;可以带上代码路径和代码名称: b OAGUPDATE.cpp:578)
break func:在函数func()的入口处设置断点,如:break cb_button
delete 断点号n:删除第n个断点
disable 断点号n:暂停第n个断点
enable 断点号n:开启第n个断点
clear 行号n:清除第n行的断点
info breakpoints(简写info b) :显示当前程序的断点设置情况
查看源代码
list(简写l):列出程序的源代码,默认每次显示10行。
list 行号:将显示当前文件以“行号”为中心的前后10行代码,如:list 12
list 函数名:将显示“函数名”所在函数的源代码,如:list main
list :不带参数,将接着上一次 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
查询运行信息
where/bt :当前运行的堆栈列表
set args 参数:指定运行时的参数
show args:查看设置好的参数
info program: 来查看程序的是否在运行,进程号,被暂停的原因
分割窗口
layout:用于分割窗口,可以一边查看代码,一边测试:
layout src:显示源代码窗口
layout asm:显示反汇编窗口
layout regs:显示源代码/反汇编和CPU寄存器窗口
layout split:显示源代码和反汇编窗口
Ctrl + L:刷新窗口
查看寄存器的值。
如果是查看所有寄存器,使用 info reg 命令(简写 i r);
如果查看单一寄存器,使用print $eax (简写 p %eax,注意这样打 印出来是十进制,如果要规定查看数据的进制,p 后接 /x 表示十六 进制,/t 表示二进制等,具体查阅 GDB 手册)
查看内存的值
命令为 “exam(简写 x) /_ _ _ 地址”
第一个空格是需要查看的数量; 第二个空格是查看数据的单位; 第三 个空格是查看数据的格式。地址可以是实际的地址值,
也可以是存有 地址值的寄存器($eax),
也可以是变量名表示的地址(&value)
例如 x/4bx 0x08408056 表示从地址 0x08408056 开始查看 4 个字节 (b) 即 8056、8057、8058、8059 四个地址中的数据, 并且是以十六 进制(x)格式查看
执行下一条指令
使用 next (简写 n)或者 step 指令(简写 s)执行下一条指令
调试时根据即将执行的指令内容, 先查看当前相关变量、寄存器、内 存的值, 执行下一条后, 再看目标操作数的值是否发生了期望中的改 变,获得了指令执行的结果,从而达到调试目的。
原文链接:https://blog.youkuaiyun.com/u010697897/article/details/51612503