gdb启动调试程序
gdb filename
gdb attach pid(running process)
gdb filename coredump
ctrl + c #终端程序
run® #启动或重启程序
backtrace #查看当前线程的调用堆栈
frame(f) 堆栈编号 #切换到指定调用堆栈
list(l) #查看当前堆栈的代码行的前后几行(具体多少行可以自行指定)
info threads #查看当前程序线程信息 – “*” 表示当前调试器所在线程
thread 线程编号 #将调试器切换到指定线程
加断点
break(b) + 行号
break(b) + 文件名:行号
break(b) + 函数名 break main
func()
func(int i)
info breaks #查看断点
delete + 断点编号(info breaks查看) 删除一个断点
disable/enable + 断点编号 #禁用/启用断点
break xxx if yy == zz #条件断点
加临时断点 – 执行一次就没有了
tbreak #方法同break
附加到进程调试
gdb 程序名 进程号
gdb EchoServer.out 48012
断点并调试
break main
run
next(n) #单步执行
continue #恢复运行 知道遇到断点
step(stepinto) #进入一个函数内部
return/finish #从当前函数直接返回出去
until + 行号 #直接运行到指定行数(遇到断点也会停)
print #查看变量值
ptype #查看变量类型
print *指针对象 #查看指针对象的内容
#当字符串太长显示不完全时 可以用如下命令设置后在看
set print element 0
display + 变量名 #动态显示一些变量值
watch + 变量名 #监视一个变量 – 当变量发生变化时 就打印出来
info display/watch #查看监视了哪些变量
undisplay + 编号 #删除display变量
设置命令行参数
set args 参数1 参数2 #设置命令行参数
show args #显示命令行参数
set args #删除命令行参数
jump 行号 #跳到指定行执行 可以简写成j不可以写成jmp
查看内存值
p &v #查看变量地址
x命令 - 查看地址
x/4bx 0x806123 # 查看从地址 0x806123 开始的 4个 byte (可以加上u表示无符号,ub) 后面的x说明是16进制输出
b - byte
h - 双byte
w - 四byte
g - 八byte
(gdb) x/6bx 0x7fffffffde90
0x7fffffffde90: 0x21 0x44 0x4f 0xf0 0xec 0x0c
(gdb) x/6hx 0x7fffffffde90
0x7fffffffde90: 0x4421 0xf04f 0x0cec 0x0a00 0x6144 0x6574
(gdb) x/6wx 0x7fffffffde90
0x7fffffffde90: 0xf04f4421 0x0a000cec 0x65746144 0x3032203a
0x7fffffffdea0: 0x39820ceb 0x31313931
(gdb) x/6gx 0x7fffffffde90
0x7fffffffde90: 0x0a000cecf04f4421 0x3032203a65746144
0x7fffffffdea0: 0x3131393139820ceb 0x6fdacf9db1313c00
0x7fffffffdeb0: 0x00007fffffffded0 0x00000000004164a2
汇编代码
disassemble(disas) 函数名 #显示某函数的汇编代码 /m — disas /m func c代码和汇编代码对照