GDB调试

基本流程

gcc -g file.c -o prog

gdb prog

(gdb) break function_name

(gdb) run

基本常用命令

help

后面跟命令名称可以查看相关命令的用法

list

1. 直接list可以列出当前所在附近的代码,连续的list会顺着上次结束的地方继续列出代码

2. list function_name可以列出该函数附近的代码

info

info break:查看当前设置的断点情况

info locals:查看当前函数内局部变量的情况

info args:查看当前函数的参数情况

print

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

set varibale=value:修改变量的值

break

break function_name:在函数入口处设置断点

break filename:lineno:在指定文件的第几行设置断点

delete

delete bk1 [bk2 bk3....]:删除指定的断点,可以用info break查看断点编号然后在这里选择删除

delete:不跟参数则可以选择删除所有的断点

continue

继续执行直到下一个断点

next

下一步,会执行整个函数,把函数当成一条语句

step

下一步,会进入函数内部

where:

有时候命令执行太多不知道当前在哪一行了,可以输入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:

watch variable:跟断点有些类似,在变量发生变化时中断程序

无敌的x命令:

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,这样上下箭头键可以用来翻用过的命令

GDB调试_第1张图片

你可能感兴趣的:(gdb)