GDB是在Linux命令行下对C/C++的程序进行调试常用的一个命令,现将平时记录在本子上的笔记整理如下:

一、断点

  断点类型有breakpoints, watchpoints, catchpoints.

1).breakpoints:   普通断点,程序运行到该点时暂停(此时此行尚未运行),是gdb中最常用的断点,相关命令为:

  break [函数名,行数或者指令地址]  [condi]  :在指定地方加上断点

例:

  (gdb) set $counter = 0
  (gdb) break 26 if ++$counter == 99

  在第26行设置断点,每次触发断点的时候执行判断条件,仅在判断条件为真的时候使程序在断点处停止。在循环的debug中很好用。

  类似的命令还有condition等。

  rbreak RE   :在所有符合正则表达式RE的函数上加上断点

2).watchpoints: 也称为data breakpoints,在表达式值变化时停止执行的断点。

  watch expr[thread threadnum]   表达式可以是变量值,地址(如*(int *)0x12345678)或数学表达式。

3).catchpoints:  程序事件断点,如c++异常

  catch event   :event可以是 throw或catch事件

查看断点:

  info breakpoint[n]  : 打印所有(或者第n个)断点信息,同 info break

  info watchpoints[n]  : 同上

删除断点:

  delete [断点号] [range...]  :range是断点号,空格分割

  clear location   :location是函数名,行数等

  enable/disable  :使能/使失效断点,不删除

其他:

为断点号bnum写一个命令列表,程序运行到断点时gdb会依次运行列表中的命令:

  commands [bnums]

    ...command list...

    end

 二、单步调试

1)基本命令:

  step:运行下一步(即step into,进入调用的函数体内)

  next:同上,但是不进入函数体

  finish:往下运行直至当前栈帧(下面解释)中的函数返回

  continue:往下运行直至遇到断点

打印信息:

  print/x data:以x(十六进制)格式打印数据data的值(或者缩写为p/x data);

输出格式有x、d、u、o、t(二进制,two,因为b已经用来表示byte)、a(address)、c(char)、f(float)、s(string)、r(raw)     

  查看数据类型: ptype data;

  打印数组: p *array@len

    

2)栈帧(stack frame)是在栈中为参数、返回地址和局部变量保留的一块内存区,必要时在过程调用中使用,相关命令:

  frame[args]:从一个栈帧移动到另一个,并打印选择的栈帧。args可以是栈帧号或其地址。

  info frame []:查看栈帧的详细信息

  backtrace:向后追踪栈帧(调用)

3)底层信息:

  查看汇编:disassemble [option] [range]

接收一个参数时,打印该地址周围的函数的汇编,接收两个参数时,表示需要dump的范围

  查看内存:x  /nfu addr

n:重复数。默认为1,表示要显示多少内存(以单元u为基数)

f:显示格式。同print,默认为x, i表示机器指令

u:单元大小。分别可以是b(byte)、h(halfwords,=2byte)、w(words,=4byte)和g(gaint words,=8byte);默认为w

  寄存器:

$pc:程序计数器,值为下一条指令的地址

$ps:程序状态寄存器

$sp:stack pointer栈指针

$fp:frame pointer 指向当前栈帧的指针

三、变更执行

1)修改变量

  print i=num,赋值并打印变量i

  set i=num,仅赋值

2)修改内存

  用'{...}'结构来生成地址。如:

  set {int}0x83040 = 4;  //将4存储到地址0x83040中

3)跳转

  jump [location]

location可以是行号或者地址。注意jump命令仅仅改变$pc的值,而不改变当前栈帧、堆栈指针或上下文,效果相当于set $pc = {int}location

4)中断

  signal sig  //立即将信号sig发给程序

5)其他

  return:使(函数)返回

  

GDB笔记的更多相关文章

  1. gdb笔记 ---《Linux.C编程一站式学习》

    gdb笔记 ---<Linux.C编程一站式学习> 单步执行和跟踪函数调用 函数调试实例 #include <stdio.h> int add_range(int low, i ...

  2. c语言,gdb

    Get gdb call stack http://blog.csdn.net/zoufeiyy/article/details/1490241 Debugging with GDB - Examin ...

  3. GDB调试基础

    GDB调试基础 https://lesca.me/archives/gdb-basic-knowledge.html GDB笔记(二):条件断点.命令列表.监视点 https://lesca.me/a ...

  4. GDB调试笔记

    参考资料:GDB调试精粹及使用实例 # 调试实例 #include <iostream> #include <cstring> using namespace std; ][] ...

  5. ubuntu: qemu+gdb 调试linux kernel 学习笔记

    声明: 本笔记内容并非本人原创,90%来自网络资料的整合.同时,由于自己是刚刚接触qemu & gdbserver remote debug,本文也就算不得教程,仅供有缘人参考而已. ---- ...

  6. 用gdb调试程序笔记: 以段错误(Segmental fault)为例

    用gdb调试程序笔记: 以段错误(Segmental fault)为例[转] 1.背景介绍2.程序中常见的bug分类3.程序调试器(如gdb)有什么用4.段错误(Segmental fault)介绍5 ...

  7. 《软件调试的艺术》学习笔记——GDB使用技巧摘要

    <软件调试的艺术>学习笔记——GDB使用技巧摘要 <软件调试的艺术>,因为名是The Art of Debugging with GDB, DDD, and Eclipse. ...

  8. 手把手教你使用eclipse+qemu+gdb来单步调试ARM内核【学习笔记】

    平台信息:linux4.0 平台:qemu 作者:庄泽彬 说明:笨叔叔的Linux视频的笔记 一.编译linux源码 export CROSS_COMPILE=arm-linux-gnueabi- e ...

  9. gdb使用笔记

    相关编译选项: 1.-g 开启gdb 2.-o0,o2  o0表示不优化, 3. -funsigned-char -fdata-sections 会使compiler为每个function和data ...

随机推荐

  1. react-native-vector-icons 安装

    react-native-vector-icons 是可以直接使用图片名就能加载图片的第三方,类似于web的iconfont矢量图,使用很方便, 你不需要在工程文件夹里塞各种图片, 节省很多空间,下面 ...

  2. Android Error:You must supply a layout_width attribute……

    出现这种情况的可能原因目前本人碰到的有: 1:在xml文件中某个属性名或者属性值写错,请务必仔细检查你有没有写错某个拼写. 2:当你在,比如TextView中,没有声明layout_width,经测试 ...

  3. Python数据结构——栈、队列的实现(二)

    1. 一个列表实现两个栈 class Twostacks(object): def __init__(self): self.stack=[] self.a_size=0 self.b_size=0 ...

  4. opencv初体验

    http://guoming.me/opencv-config  这篇文章有讲解opencv的安装与配置 一些常用库 opencv_core249d.lib opencv_imgproc249d.li ...

  5. telnet命令判断端口是否通不通

    以上得出结论80端口不通 如果连接成功,想要退出telnet的话,ctrl+],然后输入quit 查看iptables vi /etc/sysconfig/iptables   #编辑防火墙配置文件  ...

  6. int main(int argc,char* argv[]) 简单理解

    (1)第一个int代表整个main函数的返回值,若函数正常执行完毕,返回0,异常返回则是-1 (2)int argc代表命令行参数的总个数,既然是个数,那就是整型的,即:int; (3)char* a ...

  7. 高效开发Android App的10个建议(转)

    假如要Google Play上做一个最失败的案例,那最好的秘诀就是界面奇慢无比.耗电.耗内存.接下来就会得到用户的消极评论,最后名声也就臭了.即使你的应用设计精良.创意无限也没用. 耗 电或者内存占用 ...

  8. Android journey 2 @Android系统框架

    此刻,本人还是一个android菜鸟,刚刚开始起步学习android相关知识,想用blog记录自己学习的过程,一方面给他人提供帮助,另一方面给自己个复习的地方. 在一起学习Android之前,先跟大家 ...

  9. python SendMail 发送邮件

    最近在学习python 时,用到了发送邮件的操作,通过整理总结如下: 1.普通文本邮件 普通文本邮件发送的实现,关键是要将MIMEText中_subtype设置为plain,首先导入smtplib和m ...

  10. FTP操作类(支持异步)

    public delegate void DownloadProgressChangedEventHandle(string information, long currentprogress, lo ...