gcc -g file.c -o prog
gdb prog
(gdb) break function_name
(gdb) run
后面跟命令名称可以查看相关命令的用法
1. 直接list可以列出当前所在附近的代码,连续的list会顺着上次结束的地方继续列出代码
2. list function_name可以列出该函数附近的代码
info break:查看当前设置的断点情况
info locals:查看当前函数内局部变量的情况
info args:查看当前函数的参数情况
print variable:打印该变量的值
print *ptr:打印该指针指向的结构的值
print /FMT variable:在输出时指定数值格式,比如print /t var就是以二进制显示数值
o(octal), x(hex), d(decimal), u(unsigned decimal),
t(binary), f(float), a(address), i(instruction), c(char), s(string)
z(hex, zero padded on the left)
set varibale=value:修改变量的值
break function_name:在函数入口处设置断点
break filename:lineno:在指定文件的第几行设置断点
delete bk1 [bk2 bk3....]:删除指定的断点,可以用info break查看断点编号然后在这里选择删除
delete:不跟参数则可以选择删除所有的断点
继续执行直到下一个断点
下一步,会执行整个函数,把函数当成一条语句
下一步,会进入函数内部
有时候命令执行太多不知道当前在哪一行了,可以输入where
可以在run后面指定
在gdb中可以使用$varname = val的形式来定义变量,在一些语句执行后,也回显示类似$2=val,这些变量表示表达式的值,也是直接可以用的。然后这些变量可以用在如set、print这些命令中,它们可以参与运算。
source:载入gdb脚本,有些命令重复命令可以放进一个脚本然后需要执行是用source命令在当前环境里执行,和shell的source很像。
break probename if condition:在条件满足下才中断程序可以和前面指定线程的形式合起来用
until:快速执行完当前循环
finish:跳出当前函数
continue #num:表示继续执行并忽略几次断点
printf:用法与C语言版本的一致,只不过在这里调用不需要括号
set print pretty:默认情况下结构体用print输出时会挤在一起,可以使用这个设置让其按层次缩进显示。
call function_name:可以手工调用某个函数,但是不要再函数里面再打断点了
watch variable:跟断点有些类似,在变量发生变化时中断程序
x /FMT addr:
/FMT和上面print类似,但是x命令里可以指定其输出的连续内存位置上的个数。
如/4w 显示从addr开始的连续4个word的值,/4i则表示下面的连续四条指令
define printRange
set $start=$arg0
set $end=$arg1
while $start < $end
print $start
set $start=$start+1
end
end
printRanage 1 100
info threads:查看当前程序产生的线程,每个线程有个pid和gdb内部的表示id,在命令中要使用后者。
thread #internal_thread_id
break function_name thread #internal_thread_id:只有在该线程在指定的地方才设断点
set scheduler-locking on
layout:可以打开字符模拟的窗口,实现命令和代码同时显示,有好几个layout
winheight:可以调整layout中不同窗口的高度,src(源码),cmd(命令,就是普通的命令行),regs(寄存器)
fs:切换当前窗口的焦点,一般把它切换到命令窗口中,即fs cmd,这样上下箭头键可以用来翻用过的命令