应用程序调试工具gdb,王明学learn

                  应用程序调试工具gdb学习使用

一、GDB简介

GDB 是 GNU 发布的一款功能强大的程序调试工具。GDB 主要完成下面三个方面的功能:

  1、启动被调试程序。
  2、让被调试的程序在指定的位置停住。
  3、当程序被停住时,可以检查程序状态(如变量值)。

1.1gdb使用流程

1.编译生成可执行文件:

  gcc –g tst.c -o tst
2.启动 GDB
  gdb tst(文件名)
3. 在 main 函数处设置断点
  break main
4. 运行程序
  run
5. 利用更加丰富的 gdb 命令对程序进行调试。

 1.2gdb命令

1.list(l) 查看程序

2.break(b) 函数名 在某函数入口处添加断点

3.break(b) 行号 在指定行添加断点

4.break(b) 文件名:行号 在指定文件的指定行添加断点

5. info break 查看所有设置的断点

6. delete 断点编号删除断点

7.next(n) 单步运行程序(不进入子函数)

8.step(s) 单步运行程序(进入子函数)

9.continue(c) 继续运行程序知道下一个断电

10.print(p) 变量名 查看指定变量值

11. set var=value 设置变量的值

12.quit(q) 退出 gdb

二、使用Coredump解决Segment fault(段错误)

  有的程序可以通过编译, 但在运行时会出现Segment fault(段错误). 这通常都是指针错误引起的.但这不像编译错误一样会提示到文件->行,而是没有任何信息, 使得我们的调试变得困难起来.

  有一种办法是, 我们用gdb的step, 一步一步寻找.这放在短小的代码中是可行的。但如果程序代码数量比较庞大,我们就得使用另一种办法了。这时Linux系统可以把程序出错时的内存内容存储在一个core文件中, 这种过程叫Core Dump。

2.1 Core Dump要解决的问题---->段错误 Segment fault

  Linux应用程序在运行过程中,经常会遇到Segment fault(段错误) 这样的错误。产生这样错误的原因通常有:

  1. 数组访问越界

  2. 访问空指针

  3. 栈溢出

  4. 修改只读内存

2.2  Core Dump-使能

    在Linux系统中,默认是关闭core dump功能的,但是可以通过来ulimit命令打开/关闭core dump功能。

    打开:ulimit  -c  unlimited

    关闭:ulimit  -c  0

2.3  core文件分析

     发生core dump之后, 可以使用gdb进行查看core文件的内容, 以定位程序出错的位置.

     用法:gdb  程序名  core文件名

     例: gdb ./test core.12551

   在进入gdb后, 用bt命令查看backtrace以检查发生程序运行到哪里, 来定位core dump的文件->行.

2.4使用GDB+Core+file找出程序中的错误

 

posted @ 2016-03-18 19:58  for_learning  阅读(222)  评论(0编辑  收藏  举报