软件调试工具——GDB

1、GDB调试器概述

  GDB是GNU开源组织发布的一个强大的程序调试工具,具有查看程序运行状态、设置断点、查看表达式、显示变量等众多功能,是程序员进行Linux编程必须要掌握的一种调试技术。

  GDB调试工具的优势主要包含以下5个方面:

  (1)用户可以在程序运行过程中查看运行的状态;

  (2)用户可以在程序中任何需要的地方设置断点,并暂停程序的执行;

  (3)当程序暂停时,用户可以随时查看程序中各表达式、变量值以及内存值;

  (4)程序暂停时用户可以进行单步调试,依此检查程序每步运行的结果是否跟预测值一致,并且可以检查每步出现的错误;

  (5)用户可以改变程序中的变量或者执行顺序,来验证程序是否正确。

  并不是任何程序都可以使用GDB进行调试,要使用GDB进行调试必须满足两个条件:

  (1)程序必须使用GCC进行编译,并且在编译过程中添加“-g”调试信息选项。

  (2)要调试的可执行文件必须存在源程序代码,一般源程序代码存放的目录需要与可执行文件的目录相同。

  以上两个条件缺一不可,如果不添加-g选项,GDB将不能获取调试信息;如果缺少源程序代码,GDB将不能加载源文件并显示错误信息。

  在gcc编译时,因为使用优化会改变程序的运行结果,所以建议读者不要使用-O优化选项,这样才能使生成的可执行文件和源代码保持一一对应的关系;其次,用户如果想生成更多的调试信息,可在GCC编译时使用-ggdb选项。

2、GDB的启动

  GDB的启动方法非常简单,只需在命令行输入如下格式即可:

  #gdb  [options]  [file]

  此格式表示使用gdb调试工具对可执行文件file进行“options”调试。常用的选项如下:

  -b baudrate  设置远程调试的串口波特率

  --cd=DIR    进入gdb调试时改变当前路径到DIR目录

  --quiet     启动gdb后不打印许可信息

  --fullname   使用emacs-GDB交互显示输出信息

  -w        使用窗口交互

  -help      打印帮助信息

  --se=File    使用File作为可执行文件和变量文件

  --version    打印当前版本信息并退出

  --command=File  进入gdb调试后执行File文件中的命令 

3、GDB调试命令

  启动gdb后,在gdb环境中输入help就会显示所有的帮助种类。gdb把命令分成不同的类别,其中主要的种类包括:

  (1)breakpoints:断点设置类

  (2)data:    数据查看类

  (3)files:    指定并查看文件类

  (4)internals:  维护命令类

  (5)running:  程序执行类

  (6)stack:   调用栈查看类

  (7)status:   状态查看类

  (8)tracepoints:跟踪程序执行类

  help命令只是列出gdb的命令种类,如果要看种类中的子命令,可以使用help <class>命令,如:help breakpoints,表示查看设置断点的所有命令。

  GDB中比较重要的4类命令介绍:

  (1)断点设置类相关命令主要用来在调试程序中设置断点:

  break 行号:在指定的行号上设置断点

  break 函数:在“函数”名所在的行设置断点,使程序恰好在进入指定的函数前停止

  info break:显示所有断点信息

  delete 断点号:表示将指定的断点号删除,如果不指定要删除的断点号,系统默认删除所有断点号,断点号可通过info break的第一栏查询

  disable 断点号:禁止指定的断点号,同delete一样,如果不指定断点号,则禁止当前文件下所有的断点

  enable 断点号:激活指定的断点号,即激活被disable禁止的断点

  ignore 断点号 num:在程序执行中,忽略对应断点num次

  tbreak 行号或函数:设置临时断点,程序执行一次后,断点被自动删除

  watch expression:设置一个表达式的观测点

  clear [FILE:]NUM: 删除设置在特定源文件或者特定行上的断点

  clear与delete都是清除断点,但是两者的区别在于,clear命令后面要给出清除的断点所在的行的行号,而delete命令是给出清除断点的编号;其次,使用clear命令清除断点时,gdb会自动给出提示,delete命令则不会。

  (2)数据查看类相关命令可以用来查看程序中变量及内存信息:

  display [expr]:在每次程序停止时自动显示对应表达式expr的内容

  delete display [expr]:取消每次程序停止时显示对应表达式expr的内容

  delete mem:删除内存区域中的内容

  disable display [expr]:程序停止时禁止显示指定表达式expr的内容

  undisplay [expr]:禁止显示指定表达式expr的内容

  enable display [expr]:激活禁止显示的表达式expr

  print [expr][name]:打印当前表达式或变量的内容

  whatis [name]:显示变量的数据类型

  ptype [name]:显示用户结构体的定义内容

  print的显示格式:

  /x  按十六进制格式显示变量

  /d  按十进制格式显示变量

  /u  按十六进制格式显示无符号整型

  /o  按八进制格式显示变量

  /t  按二进制格式显示变量

  /a  按十六进制格式显示变量

  /c  按字符格式显示变量

  /f  按浮点数格式显示变量

  dispaly可以用来设置一些自动显示的变量,当程序暂停时,或者用户单步跟踪时,这些变量的值将会自动显示;print只能显示当前用户指定的变量或者表达式的值,当程序下一次单步执行或者暂停时,不会显示上次设定变量的值。

  (3)文件查看类命令主要用于程序文件的查看以及程序的编辑:

  cd DIR:将工作目录设置在DIR下

  directory DIR:在搜寻源文件时也搜索DIR目录

  file File:表示加载指定文件File进gdb

  search 正则表达式及变量:向前搜索正则表达式及变量

  foward-search 正则表达式及变量:向前搜索正则表达式

  reverse-search 正则表达式及变量:向后搜说正则表达式

  pwd:打印当前工作目录

  path DIR:在搜索文件路径时也搜索DIR目录

  load file:在运行程序时,动态加载file文件

  list [行号][函数名]:列出对应于正在执行的程序的源文件内容,后面不加任何参数表示显示10行源文件内容。list也可使用其缩写形式l

  info line:显示加载到内存中的代码

  (4)程序控制相关命令

  在使用GDB调试过程中大致分为3中状态:运行态、暂停态以及结束态,其中暂停态使程序暂停在某个断点处,它在程序调试中用的最多;结束态是用户调试完毕,要跳出gdb的状态,在此状态下无法查看各种变量的值;运行态是除暂停态和结束态之外的所有状态。

  run:表示执行程序

  continue:继续执行正在调试的程序,该命令用在程序由于处理信号或断点导致停止运行时

  interrupt:中断调试程序的执行

  next:单步调试程序,不进入子函数单步执行

  nexti:单步调试一条指令

  step:单步调试程序,进入子函数单步执行

  kill:终止正在调试的程序

  set args:当被调试程序开始运行时,设置程序的参数列表

  set environment:设置程序环境变量的值

  show args:显示一开始调试程序的参数列表

  set step-mode:设置单步运行的模式

  show step-mode:显示单步运行的模式

  finish:运行程序,直到当前函数完成返回,并打印函数返回时的堆栈地址和返回值及参数值等信息

  until:结束当前循环

  make:在不退出gdb的前提下执行make命令

posted @ 2013-11-17 17:32  ITtecman  阅读(797)  评论(0编辑  收藏  举报