gdb调试笔记

启动管理

# 开启调试
gdb <executable>

# 给a.out传参调试
gdb --args a.out "hello"

# 设置main参数
(gdb) set args <arg1> <arg2>

# 退出调试
q, quit

断点调试

行号断点

有源码情况下可以使用断点调试,包括普通断点和条件断点等:

# 1.显示源码
layout src #layout split 会同时显示汇编和源码
# 或者ctrl+x+a

# 2.设置断点
start # 开始运行并在main函数处断点
b 5  # 在第5行断点
b 5 if a==3 # 在第5行断点,当栈内变量a等于3时

# 3.设置自动变量
display <变量1>,<变量2>

# 4.运行
c

# 5.查看函数栈调用信息
bt

# 6.查看函数栈内的变量信息
info locals

# 7.单步调试
s #执行到下一条语句
n #执行到下一行

变量变更断点

watch <变量>

事件断点

# 子进程断点
catch [ fork | exec ]

# 信号断点
catch signal <信号>

# 事件断点
catch syscall <系统调用>

coredump调试

自动coredump文件

程序崩溃时默认不会生成coredump文件,需要以下配置才能生成coredump文件:

# 1.设置coredump文件大小为无限
ulimit -c unlimited

# 2.在root用户中设置coredump文件生成路径,这种方式设置的参数值只在当前会话中有效,系统重启后会失效。
sudo bash -c 'echo "core.%e" > /proc/sys/kernel/core_pattern'

设置后可以使用coredump文件进行调试崩溃时的函数栈信息:

# 有源码调试
gdb <可执行程序> <coredump文件>

# 无源码调试
gdb -c <coredump文件>

手动coredump文件

如果程序出现死锁,会一直处于等待状态,这时需要手动coredump:

# 手动产生coredump文件
gdb attach <进程id>
(gdb) gcore <coredump名>
(gdb) detach
(gdb) q

# 调试coredump文件
gdb <可执行程序> <coredump文件>

无源码调试

gcc -g main.c时会添加符号信息和调试信息;
gcc main.c时会添加符号信息;
strip会去除符号信息和调试信息;

# 从第一条指令调试
starti

# 单步指令调试
si
ni

# 查看寄存器信息
info registers
x/4xw 0x1000

# 设置断点
break *0x1234

常见段错误
段错误(Segmentation fault)通常是由程序访问了未分配的内存或者已经释放的内存、越界访问数组或指针等导致的。具体原因可能包括:

  • 访问了空指针或者已经释放的指针:程序试图读取或写入一个指向空地址的指针,或者试图释放已经被释放的内存块。
  • 访问了非法地址:程序访问了一个不属于它的内存地址空间,比如试图访问未分配的内存、访问已经释放的内存等。
  • 栈溢出:程序使用了太多的栈空间,导致栈溢出,比如函数递归调用过多或者局部变量太多等。
  • 越界访问数组或指针:程序访问了数组或指针的非法下标或指针偏移量,比如访问数组的负数下标、访问数组的最后一个元素之后的位置等。
  • 内存对齐问题:程序试图访问未对齐的内存地址。
  • 动态链接库问题:程序在动态链接库中调用了一个不存在的函数或者访问了一个不属于它的动态链接库中的地址等。

除了以上几种情况外,还有可能是硬件故障或操作系统错误等原因导致的段错误。因此,对于遇到段错误的情况,需要具体分析具体情况,并根据错误提示信息进行调试和排查。

多进程调试

如果想调试子进程,父进程自由执行:

# 调试fork时创建的子进程
set follow-fork-mode child

# 调试exec创建的子进程
#set follow-exec-mode new

默认状态下,gdb继续调试父进程,子进程自由执行,如果想调试子进程,则新开一个gdb附加到子进程:

(gdb) attach <子进程>

如果想在gdb上同时调试父子进程,也就是子进程创建后即中断:

# 关闭子进程分离模式
set detach-on-fork off

# 查看进程信息
info inferiors

# 切换到子进程
inferior <子进程号>

注意:
如果父进程进入了等待状态或死锁,不归还终端,可以使用Ctrl + c命令中断进程,并查看状态。

多线程调试

# 查看线程
info threads

# 切换线程
thread <线程id>

# 设置断点
b <断点号> thread <线程id>

# 为线程执行gdb命令
thead apply <线程号1> <线程号2> info locals

远程调试

# 客户机器安装gdbserver
sudo apt install gdbserver

# 客户机关闭防火墙

# 本机远程目标机ip远程调试,由于关了防火墙,端口号可以是任意的
gdbserver <ip>:<端口号> <可执行程序>
target remote <ip>:<端口号> <可执行程序>

发行版调试

# 输出调试版的符号表
objcopy --only-keep-debug <调试版二进制> <符号表>

# 使用符号表调试发布版
gdb --symbol=<符号表> -exec=<发布版>

其他

获取程序的入口地址

# 方法1
readelf -h a.out | grep Entry

# 方法2
(gdb) info files

杂项

# 刷新界面
(gdb) refresh

# 切换函数栈帧
(gdb) frame <帧号>

# 调用shell命令
(gdb) shell <命令>

# 中断程序
Ctrl + c

参考链接

Forks
调试子进程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: an1078是一篇有关微控制器调试的技术文档,文中介绍了一些常用的调试方法和技巧。在进行微控制器调试时,首先需要确定是否需要使用硬件调试工具。如果需要,可以使用示波器、电路板、信号发生器等工具进行调试。其次,需要对程序进行逐步调试。可以通过设置断点、打印变量、观察寄存器等方式进行调试。其中,断点的设置是一个非常重要的调试技巧,可以在程序执行的某个关键点暂停程序,以便观察程序的行为和状态。除此之外,还可以使用仿真工具进行调试。通过仿真工具,我们可以模拟程序运行过程,定位和解决程序中的问题。最后,当出现问题时,需要进行错误分析。可以通过查看程序代码、查看错误信息等方式进行分析。除了以上方法外,还有其他一些调试技巧,例如调试日志、覆盖率测试等。总之,在进行微控制器调试时,需要充分利用调试工具和技巧,以便快速、准确地定位和解决问题。 ### 回答2: an1078是一个使用ST-Link调试器调试STM32F1xx系列微控制器的应用笔记。这份调试笔记主要涵盖了使用ST-Link调试器调试STM32微控制器的基本步骤和注意事项。 首先,使用ST-Link调试器进行调试之前,需要先进行硬件连接。连接方法是将ST-Link调试器连接到STM32微控制器的SWD端口上,通过SWD接口进行通信。 其次,需要在调试软件中进行一些基本的设置,例如选择正确的芯片型号和验证连接。同时,还需要构建正确的调试环境,包括设置断点,监视变量和寄存器等。 在进行实际的调试过程中,需要注意一些常见的问题,例如在调试过程中遇到的编程错误和硬件问题。此外,还有一些与特定芯片型号相关的问题,例如编程失败或调试操作失败。 最后,调试完毕后,需要断开连接并保存所有的设置和调试数据。如果需要重新进行调试,可以再次连接并加载之前保存的数据。 综上所述,an1078调试笔记为STM32F1xx系列微控制器的调试提供了简明易懂的操作指南,可以帮助工程师快速进行调试并解决常见的问题。 ### 回答3: an1078是一个调试笔记,主要讲述了在调试过程中可能会遇到的问题和解决方法。调试是软件开发过程中不可或缺的一部分,是确保软件程序能够正常运行的关键步骤。 在调试过程中,可能会遇到很多问题,比如程序崩溃或出现错误信息、程序响应过慢、执行结果不符合预期等等。在这些问题出现时,开发人员需要对程序进行逐步调试,找出问题所在并进行修复。 an1078提到了一些常见的调试技巧,如打印调试信息、使用断点进行调试、分离模块进行调试、使用调试器进行调试等等。这些技巧可以帮助开发人员快速定位问题并进行解决。 此外,an1078还提到了一些调试工具,如gdb、Valgrind、strace等等,这些工具可以帮助开发人员更加高效地进行调试和分析。 总之,在软件开发过程中,调试是一项非常重要的任务,需要开发人员进行认真对待。通过采用一些有效的调试技巧和工具,可以帮助开发人员提高调试效率,从而缩短开发周期,提高软件开发的质量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

多弗朗强哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值