本文主要是介绍(二)GDBdebug调试技术——GDB的使用技巧1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 1.gdb的调试选项
- 2.gdb的使用技巧1
1.gdb的调试选项
- 构建方法一般写在INSTALL,README中
- 至少要知道, gcc的优化选项可能会让执行顺序与源代码顺序不同,eg:inline内敛函数优化(函数代码在调用的位置展开),该函数名无法设置断点
(1)若使用gcc -g
$ gcc -Wall -02 -g 源文件(2)若使用Makefile文件,则
$ CFLAGS= -Wall -02 -g(3)若使用configure脚本生成Makefile
$ ./configure CFLAGS="-Wall -02 -g"
2.gdb的使用技巧1
(1)启动
$ gdb 可执行文件名 (2)设置断点break(b)
(gdb) break 断点
用法:
break 函数名
break 行号
break 文件名:行号
break 文件名:函数名
break +偏移量
break -偏移量
break *地址(3)查看断点
(gdb) info break(4)运行run(r):执行到设置的断点位置处暂停
(gdb) run
等于
(gdb) start(5)显示栈帧backtrace(bt)
(gdb) bt
等价于 (gdb) where ,(gdb) info stack(info s)
用法:
只显示前3个栈帧,即栈的编号是#0, #1, #2
(gdb) bt 3从外向内显示3个栈帧,及其局部变量
(gdb) bt full -3(6)显示变量print(p)
(gdb) p 变量
eg:
(gdb) p argv[0]
$3=oxbf9cf6a5 "/home/jiwangreal/uname"(gdb) p argv[1]
$3=oxbf9cf6cd "-a"
表示:argv[0]中为可执行文件名:/home/jiwangreal/uname
argv[1]中为第一个选项:-a(7)显示寄存器info registers
(gdb) info reg显示各个寄存器的内容,在寄存器名前加$
(gdb) p $eax十进制的97为ASCII的'a'
(gdb) p/c $eax程序指针$pc和$eip是一样的
(gdb)p $pc
(gdb)p $eip
$9=(void(*)())0x4048ebd <main+173>(8)显示内存的内容eXamining(x)
x/格式 地址
(gdb) x $pcx/i表示显示汇编指令
(gdb) x/i $pc 用法:
(gdb)x/NFU ADDR
ADDR:显示的地址
N:重复次数
F:x,d,u,o,t,a,c,f,s,i格式
U:U所示的单位从pc所指地址开始的10条指令
(gdb)x/10i $pc(9)反汇编disassemble(disas)
格式:
disas
disas 程序计数器
disas 开始地址 结束地址(gdb)disas $pc $pc+50(10)单步执行
next(n):执行源代码中的一行
step(n):执行到函数内部(11)继续运行continue(c):程序会在遇到断点后再次暂停运行
格式:c c 次数continue5则5次遇到断点不停止,第6次遇到断点才暂停执行(gdb) c 5(12)监视点warchpoint
格式:
watch <表达式>
<表达式>发生变化时暂停运行,<表达式>:常量,变量等awatch <表达式>
<表达式>被访问,改变时暂停运行rwatch <表达式>
<表达式>被访问,改变时,暂停运行(gdb)awatch shot_out
变量shot_out的值,发生变化时就会暂停运行(13)删除断点和监视点delete(d)
格式:
d <编号>
删除<编号>指示的断点或监视点(gdb)info b
(gdb)delete 2 删除2号断点(14)改变变量的值
格式:
set variable <变量>=<表达式>
(gdb)set variable options=0(15)生成coredump文件
可将调试中的进程生成coredump文件
(gdb)generate-core-filegcore命令可以从命令行直接生成coredump文件,该命令无需停止正在运行的程序以获得coredump文件
(gdb)gcore 'pidof emacs'
- 显示寄存器的可使用的格式
- x/NFU ADDR 中U代表的含义
参考:《GDB/Debug.Hacks中文版:深入调试的技术和工具》
这篇关于(二)GDBdebug调试技术——GDB的使用技巧1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!