如何用GDB调试多线程程序

栏目: C · 发布时间: 7年前

内容简介:如何用GDB调试多线程程序

先写一段多线程程序。

如何用GDB调试多线程程序
makefile 如何用GDB调试多线程程序

加上 -g参数生成可调式信息, 可以进行调试。

pthread不是 Linux 下的默认的库,也就是在链接的时候,无法找到phread库中哥函数的入口地址,于是链接会失败。在gcc编译的时候,附加要加 -lpthread参数即可解决。

  • gdb test 进入调试

如何用GDB调试多线程程序

  • 需要调试的地方打下断点,run运行到断点处。

如何用GDB调试多线程程序

  • r 运行到断点处,info thread可以查看被调试的线程。

如何用GDB调试多线程程序

  • thread apply all bt 让所有线程打印堆栈信息

    如何用GDB调试多线程程序

set scheduler-locking off|on|step

在使用step或continue命令调试当前被调试线程的时候,其他线程也是同时执行的,如果我们只想要被调试的线程执行,而其他线程停止等待,那就要锁定要调试的线程,只让它运行。

off:不锁定任何线程,所有线程都执行。

on:只有当前被调试的线程会执行。

step:阻止其他线程在当前线程单步调试的时候抢占当前线程。只有当next、continue、util以及finish的时候,其他线程才会获得重新运行的。

show scheduler-locking:

这条命令是为了查看当前锁定线程的模式。


以上所述就是小编给大家介绍的《如何用GDB调试多线程程序》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

从Paxos到Zookeeper

从Paxos到Zookeeper

倪超 / 电子工业出版社 / 2015-2-1 / 75.00元

《Paxos到Zookeeper:分布式一致性原理与实践》从分布式一致性的理论出发,向读者简要介绍几种典型的分布式一致性协议,以及解决分布式一致性问题的思路,其中重点讲解了Paxos和ZAB协议。同时,本书深入介绍了分布式一致性问题的工业解决方案——ZooKeeper,并着重向读者展示这一分布式协调框架的使用方法、内部实现及运维技巧,旨在帮助读者全面了解ZooKeeper,并更好地使用和运维Zoo......一起来看看 《从Paxos到Zookeeper》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

SHA 加密
SHA 加密

SHA 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具