Chinaunix首页 | 论坛 | 博客
  • 博客访问: 498949
  • 博文数量: 223
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2145
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-01 10:23
个人简介

该坚持的时候坚持,该妥协的时候妥协,该放弃的时候放弃

文章分类

全部博文(223)

文章存档

2017年(56)

2016年(118)

2015年(3)

2014年(46)

我的朋友

分类: C/C++

2016-10-13 23:04:39

一、GDB简介

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

1、启动被调试程序。

2、让被调试的程序在指定的位置停住。

3、当程序被停住时,可以检查程序状态。(如变量值)


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

gcc-gtst.c -o tst

2.启动GDB

gdb tst

3. main

在 函数处设置断点

break main

4.运行程序

run

5.利用更加丰富的gdb命令对程序进行调试。


二、GDB命令

list(l)查看程序

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

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

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

info break查看所有设置的断点

delete断点编号 删除断点

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

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

continue(c)继续运行程序

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

set var=value设置变量的值

quit(q)退出gdb

三、Core Dump-定义
Core Dump又叫核心转存。当程序在运行过程中发生异常, 这时Linux系统可以把程序出错时的内存内容存储在一个core文件中, 这种过程叫Core Dump。

1.Core Dump主要用来对付什么样的错误呢?Segment fault

Linux应用程序在运行过程中,经常会遇到Segment fault(段错误) 这样的错误。产生这样错误的原因通常有:
数组访问越界、访问空指针、栈溢出、修改只读内存

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

打开:ulimit -c unlimited

关闭:ulimit -c 0


3.Core文件分析
发生core dump之后,可以使用gdb进行查看core文件的内容,以定位程序出错的位置
用法:gdb程序名core文件名
例: gdb./testcore.12525

两个调试代码:

  1. #include <stdio.h>

  2. #include <stdlib.h>



  3. void main()

  4. {

  5.     int *ptr = NULL;

  6.     *ptr = 0;

  7. }

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>

  4. void main()
  5. {

  6.      char *ptr = "123456";

  7.         ptr[0] = '7';
  8. }



阅读(386) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~