ref : https://blog.csdn.net/seu_lyr/article/details/9050657

 

一 暂停程序的运行:

(一)GDB的暂停方式:断点(BreakPoint)、观察点(WatchPoint)、捕捉点(CatchPoint)、信号(Signals)、线程停止(Thread Stops)。如果要恢复程序运行,使用continue或c命令。

*GDB中的停止点:断点(BreakPoint)、观察点(WatchPoint)、捕捉点(CatchPoint)。

 

(二)设置断点:用break命令设置断点。

*break <function>:在进入指定函数时停住。C++可以使用class::function或function(type,type)(重载)格式来指定函数名。

*break filename:function:在源文件filename的function函数入口处停住。

*break<linenum>:在指定行号停住。

*break filename:linenum:在文件filename的linenum行处停住。

*break +offset和break -offset:在当前行的前或后offset行停住。

 

*break *address:在程序运行时内存地址address处停住。

 

*break:没有参数时,表示在下一条指令处停住。

*break ... if<condition>:...可以是上述参数,condition表示条件,在条件成立时停住。例如:break linenum if i==5.

 

*查看断点:info break [n]或info breakpoint [n]。n表示断点号,[]表示可选,没有n则显示全部断点。

 

(三)设置观察点(硬件观察点和软件观察点)watch:用来观察某个表达式(包括变量)的值是否变化,如果变化,则马上停止程序。

*watch <expr>:为表达式expr设置一个观察点,一旦表达式的值有变化,马上停止程序。

*rwatch <expr>:expr被读时,停止程序。

*awatch <expr>:当表达式expr的值被读或被写时,停住程序。

*info watchpoints:显示当前设置的所有观察点。

 

(四)捕捉点:捕捉程序运行时的一些事件。如:载入共享库或是C++异常。

1.格式:catch <events>

*当event发生时,停住程序。

*twach<events>:只设置一次捕捉点,当程序停住以后,捕捉点被删除。

2.events:



(五) 维护停止点:

1.clear:


2.delete:


3.disable:gdb不删除,需要时再enable即可。


4.enable:


 

(六)维护停止条件:

1.condition <bnum> <expression>:修改断点号为bnum的停止条件为expression。

*condition <expression>:清楚断点为bnum的停止条件。


2.ignore <bnum> <count>:忽略断点为bnum的停止条件count次。


 

(七) 为停止点设定运行命令:

(1)利用commands命令设置停止点的运行命令,当程序被停止时,可以让其自动运行一些别的命令(有利于自动化测试)。

(2)格式:

commands [bnum]

... command-list ...

end

(3)help commands:


(4)例如:

/*在断点1处打印i的值,并继续运行程序*/

commands 1

print i

continue

end

 

(八) 断点菜单:

(1)在C++中可能有函数重载,这种情况下break<function>不能告诉gdb要停在哪个函数的入口。可以用break
<function(type)>指定哪个函数,否则gdb会列出一个断点菜单供你选择,这时只需输入菜单列表的编号即可。

 

(九) 信号(signals):

(1)信号是一种软终端,一种处理异步事件的方法。GDB有能力在你调试程序时处理任何一种信号,可以告诉GDB需要处理哪一种信号。要求GDB在收到你所指定的信号时,马上停住正在运行的程序,供你调试,利用handle命令完成。

(2)handle命令:格式:handle <signal> <actions>,参数见help handle。


 

(十)线程停止(thread stops):

(1)如果程序是多线程程序可以定义断点在所有线程上还是在特定线程上。

(2)格式:break <linespec> thread <threadno>或break <linespec> thread <threadno> if ...

*linespec指定断点设置的源程序的行号。threadno指定线程的ID,注意这个ID是GDB分配的,可通过info threads来查看正在运行程序的线程信息。如果不指定thread <threadno>就将断点设置在所有线程上。

 

 

二 恢复程序的运行:

(1)continue:当程序被停住,可以用continue命令恢复程序的运行直到程序结束,或下一个断点到来。


 

(2)next、step、until和finish:

gdb暂停或恢复程序的运行的更多相关文章

  1. gdb常用命令及使用gdb调试多进程多线程程序

    一.常用普通调试命令 1.简单介绍GDB 介绍: gdb是Linux环境下的代码调试⼯具.使⽤:需要在源代码⽣成的时候加上 -g 选项.开始使⽤: gdb binFile退出: ctrl + d 或 ...

  2. gdb常用命令及gdb调试多进程/线程程序&coredump

    一.常用普通调试命令 1.简单介绍GDB 介绍: gdb是Linux环境下的代码调试⼯具.使⽤:需要在源代码⽣成的时候加上 -g 选项.开始使⽤: gdb binFile退出: ctrl + d 或 ...

  3. gdb调试多进程多线程程序

    一.调试的指令 1.list命令 list linenum 显示程序第linenum行的周围的程序 list function 显示程序名为function的函数的源程序 list 显示当前行后面的源 ...

  4. 利用ManualResetEvent来来控制异步调用的打印的线程的暂停和恢复(转)

    利用ManualResetEvent来来控制异步调用的打印的线程的暂停和恢复 打印过程可能很长,这时候有可能需要暂停下来做一些事情,然后回来继续接着打印 打印过程中有2个线程:一个是程序运行的主线程, ...

  5. 更为复杂C程序的运行时结构

    运行环境 win 10 企业版 1809 17763.194,MinGW V3.14 32位,Bundled V3.13.2,Bundled GDB V8.2. 在C语言中,栈的方向是从高地址向低地址 ...

  6. Linux暂停和恢复进程

    Linux暂停和恢复进程 kill -STOP 1234 将该进程暂停. 如果要让它恢复到后台,用kill -CONT 1234 (很多在前台运行的程序这样是不行的) 如果要恢复到前台,请在当时运行该 ...

  7. javascript 函数的暂停和恢复

    javascript 异步编程从来都是一个难题,最开始我们用 callback,但随之触发了回调地狱,于是"发明" Promise 解决 callback 嵌套过深的问题.然而由于 ...

  8. 使用 suspend 和 resume 暂停和恢复线程

    suspend 和 resume 的使用 在 Thread 类中有这样两个方法:suspend 和 resume,这两个方法是成对出现的. suspend() 方法的作用是将一个线程挂起(暂停), r ...

  9. Eclipse+CDT+GDB调试android NDK程序(转)

    Eclipse+CDT+gdb调试android ndk程序 先介绍一下开发环境,在这个环境下,up主保证是没有问题的. ubuntu 11.10 eclipse 3.7(indego) for ja ...

随机推荐

  1. CF1197A

    CF1197A 题意: 定义k阶梯子为两边各一块木板长度至少k+1,中间k块木板至少为1 .问 给你n块木板,最多能搭成几阶的梯子. 解法: 读题两小时,代码五分钟. 考虑贪心,构成梯子的两侧的木棍一 ...

  2. flask 设置配置文件的方式

    from flask import Flask from flask import current_app """ 配置参数设置与读取 """ ...

  3. vagrant box镜像百度下载地址

    1.centos7 链接:https://pan.baidu.com/s/1JuIUo4HL0lm1EtUKaoMpaA提取码:w9a8 2.vagrant-ubuntu-server-16.04-x ...

  4. kotlin之函数的范围和泛型函数

    kotlin 中函数可以定义为局部函数,成员函数以及扩展函数 局部函数:就是嵌套在函数内的函数 成员函数就是定义在类或者对象之内的函数 泛型函数就是函数可以带有泛型参数,可通过尖括号来指定

  5. 阶段5 3.微服务项目【学成在线】_day05 消息中间件RabbitMQ_4.RabbitMQ研究-安装RabbitMQ

    RabbitMQ由Erlang语言开发,Erlang语言用于并发及分布式系统的开发,在电信领域应用广泛,OTP(Open Telecom Platform)作为Erlang语言的一部分,包含了很多基于 ...

  6. hdfs操作命令

    文件操作命令:hdfs dfs -ls /hdfs dfs -mkdir /hdfs dfs -rm -rf /hdfshdfs dfs -duhdfs dfs -get /hdfs /localhd ...

  7. AppCode 2016.3 注册码

    43B4A73YYJ-eyJsaWNlbnNlSWQiOiI0M0I0QTczWVlKIiwibGljZW5zZWVOYW1lIjoibGFuIHl1IiwiYXNzaWduZWVOYW1lIjoiI ...

  8. CentOS下Hadoop及ZooKeeper环境搭建

    1. 测试环境 操作系统 CentOS 6.5. 总共5台机器,前两台作为namenode,称之为 nn01.nn02:后三台作为datanode,称为 dn01.dn02.dn03. 每台机器的内存 ...

  9. EasyNetQ使用(三)【Publish与Subcribe】

    EasyNetQ支持的最简单的消息模式是发布/订阅.这个模式是一个极好的方法用来解耦消息提供者和消费者.消息发布者只要简单的对世界说,“这里有些事发生” 或者 “我现在有一个信息”.它不关心有没有人监 ...

  10. Path环境变量的作用

    作用: 当我们要求系统运行一个程序(例如a.exe)而没有告诉它程序所在的完整路径时,系统会先在当前目录寻找是否存在a.exe,如果找到,直接运行:如果没有找到,会去path路径下面找.设置path, ...