GDB
一、基本命令
命 令
|
简
|
描 述
|
gdb
|
|
gdb [filename] [core]
|
set
|
|
set arg -?设置参数
|
directory
|
|
directory DIR
|
file
|
f
|
装入想要调试的可执行文件.
|
kill
|
|
终止正在调试的程序.
|
list
|
l
|
list列出产生执行文件的源代码的一部分. |
next
|
n
|
执行一行源代码但不进入函数内部.
|
step
|
s
|
执行一行源代码而且进入函数内部.
|
run
|
r
|
r [args]执行当前被调试的程序
|
until
|
u
|
执行一行程序,若此时程序是在 for/while/do loop 循环的最后一行,则一直执行到循环结束后的第一行程序后停止 (until 指令可简写为 u)。
|
finish
|
|
执行现行程序到回到上一层程序为止。(gdb) finish |
quit
|
q
|
终止 gdb
|
print
|
p
|
print 叙述,显示该叙述执行的结果
|
display
|
|
display 叙述,在每个断点或是每执行一步时显示该叙述值
|
watch
|
|
使你能监视一个变量的值而不管它何时被改变.
|
break
|
b
|
(gdb) break filename.c:30 => 在 filename.c 的第三十行处停止执行 |
info
|
|
(gdb) info break
|
clear
|
|
清除断点(命令为 clear),格式同 break 。例如 :(gdb) clear filename.c:30
|
delete
|
|
(gdb) delete NUM 清除断点,NUM 是在 info break 显示出来的断点编号。
|
disable
|
|
(gdb) disable NUM 暂停某个断点
|
enable
|
|
(gdb) enable NUM 启动某个断点
|
backtrace
|
bt
|
查看程序执行到此时,是经过哪些函数呼叫的程序 (backtrace 指令可简写为 bt),也就是查看函数呼叫堆栈。
|
make
|
|
使你能不退出 gdb 就可以重新产生可执行文件.
|
shell
|
|
使你能不离开 gdb 就执行 UNIX shell 命令.
|
二、基本的使用方法简介
前言
程序代码中的错误可分为数类,除了最容易除错的语法错误,编译程序会告诉你错误所在外,大部分的错误都可以归类为执行时错误。GDB 的功能便是寻找执行时错误。如果没有除错程序,我们只能在程序中加入输出变量值的指令来了解程序执行的状态。有了 GDB 除错程序,我们可以设定在任何地方停止程序的执行,然后可以随意检视变量值及更动变量,并逐行执行程序。
一个除错程序执行的流程通常是这样的:
1. 进入除错程序并指定可执行文件。
2. 指定程序代码所在目录。
3. 设定断点后执行程序。
4. 程序于断点中断后,可以 (1)检视程序执行状态;检视变量值或变更变量值 (2) 逐步执行程序,或是全速执行程序到下一个断点或是到程序结束为止。
5. 离开除错程序。
以下将分为下列数项分别介绍:
1. 进入 GDB 及指定可执行档
2. 指定程序代码所在目录及检视程序代码
3. 断点的设定与清除
4. 全速及逐步执行程序
5. 检视及更改变量值
6. 检视程序执行状态
7. 读取 Core 文件信息
进入 GDB 及指定可执行档:
1. 进入 GDB 并读入可执行档 (档名为 'PROGRAM'),准备进行除错。
gdb PROGRAM
set ags -? (设置参数,即向你要调试的程序传参)
指定程序代码所在目录及检视程序代码
1. 增加目录 DIR 到收寻程序代码的目录列表 (如果你的程序代码和可执行档放在同一个目录下,就不须指定程序代码所在目录。):
(gdb) directory DIR
2. 检视程序代码,格式计有:
(gdb) list => 显示目前执行程序代码前后各五行的程序代码;或是显示从上次 list 之后的程序代码
(gdb) list function => 显示该程序开始处前后五行的程序代码。
(gdb) list - =>上次显示程序代码的前面的十行。
断点的设定与清除
1. 设定断点(指令为 break,可简写为 (b),格式计有:
(gdb) break filename.c:30 => 在 filename.c 的第三十行处停止执行。
(gdb) break function => 在进入 function 时中断程序的执行。
(gdb) break filename.c:function => 在程序代码档 filename.c 中的函数 function 处设定断点。
(gdb) break => 在下一个将被执行的命令设定断点。
(gdb) break ... if cond => 只有当 cond 成立的时候才中断。cond 须以 C 语言的语法写成。
2. 显示各个断点的信息。
(gdb) info break
3. 清除断点(命令为 clear),格式同 break 。例如 :
(gdb) clear filename.c:30
4. 清除断点,NUM 是在 info break 显示出来的断点编号。
(gdb) delete NUM
全速及逐步执行程序
1. 从程序开头全速执行程序,直到遇到断点或是程序执行完毕为止。
(gdb) run
2. 在程序被中断后,全速执行程序到下一个断点或是程序结束为止 (continue 指令可简写为 c)。
(gdb) continue
3. 执行一行程序. 若呼叫函数, 则将该包含该函数程序代码视为一行程序 (next 指令可简写为 n)。
(gdb) next
4. 执行一行程序. 若呼叫函数, 则进入函数逐行执行 (step 指令可简写为 s)。
(gdb) step
5. 执行一行程序,若此时程序是在 for/while/do loop 循环的最后一行,则一直执行到循环结束后的第一行程序后停止 (until 指令可简写为 u)。
(gdb) until
6. 执行现行程序到回到上一层程序为止。
(gdb) finish
检视及更改变量值
1. print 叙述,显示该叙述执行的结果 (print 指令可简写为 p)。如
(gdb) print a => 显示 a 变量的内容.
(gdb) print sizeof(a) => 显示 a 变量的长度.
2. display 叙述,在每个断点或是每执行一步时显示该叙述值。如
(gdb) display a
3. 更改变量值:
(gdb) print (a=10) => 将变量 a 的值设定为 10.
检视程序执行状态
1. 查看程序执行到此时,是经过哪些函数呼叫的程序 (backtrace 指令可简写为 bt),也就是查看函数呼叫堆栈。
(gdb) backtrace
读取 Core 文件信息
1. 读入 PROGRAM 及 PROGRAM.CORE 档,可检视 Core Dump 时程序变量值及程序流程状态 。
gdb PROGRAM core
说明:'core' 档案是由 PROGRAM 档执行后,遇到 Core Dump 时产生的 Core 檔檔名。如果你还需要该 Core 档,我们建议你将该档案档名更改为 PROGRAM.core。在输入上述命令后,你可以用 GDB 提供的检视变量值以及检视程序执行状态来读取程序 Core Dump 时的状态。
补充一点儿
(最近我刚在用gdb,感觉还不错,不过有的时候还是眼睛加printf更好
使)
我更多是用gdb直接调试程序,而不是core
gdb 可执行文件名 (进入gdb环境)
set ags -? (设置参数,即向你要调试的程序传参)
另外,用break functionName 和break lineNum都可以设置断点
用info break 可以查看当前断点的信息
用clear清除断点的时候要和break相对应
如果是用functionName设置的断点就只能 clear functionName
用lineNum设置的断点就只能用clear lineNum
BTW:可以到www.sunfreeware.com去下载gdb
以上是我近几天学习gdb的一点经验,都是我犯过错误的地方
希望对与我等同类的gdb菜鸟们有所帮助。
如果是刚开始时也可以使用ddd
图形化的
另外对于断点可以使用
delete 断点号
删除
断点号可以使用info break 得到
我也说说我的体会:
r (程序运行的参数) 可以设置运行时的参数
shell 运行shell环境的东西,比如shell make,完了以后直接r重新启动程序,就可以带上次已经加过的参数运行,不用再敲参数了
b 文件名:行号 有的时候很有用,嘿嘿
info b 看断点信息
disable 断点号 暂停某个断点
enable 断点号 启动某个断点
delete (断点号) 删除某个断点,不带断点号,全部删除
x/32uxb 指针 以16进制显示该指针指向的32个字节的数据
不过我还是不会用core调试,呵呵