博客
关于我
Linux下gdb调试器的简单使用方法
阅读量:612 次
发布时间:2019-03-13

本文共 1393 字,大约阅读时间需要 4 分钟。

“GDB”

What

GDB(GNU symbolic debugger)是 GNU Project 调试器,它使你可以查看另一个程序在“执行”期间正在执行的操作–或该程序崩溃时正在执行的操作暨①调试可执行程序②调试Coredump文件。

GDB 可以做四种主要的事情(以及支持这些事情的其他事情)来帮助你捕获行为中的错误:

启动你的程序,并指定可能影响其行为的所有内容。

使程序在指定条件下停止。
检查程序停止时发生的情况。
更改程序中的内容,以便你可以尝试纠正一个错误的影响,然后继续学习另一个错误。

How

使用“GDB”调试器的前提是调试对象是“调试版本(debug)”的二进制程序,在Linux下gcc/g++编译出来的二进制程序默认是“发布版本(release)”,因此在源代码编译时需要加上“-g”选项,我们以求斐波那契数的程序为例:

调试可执行程序

在这里插入图片描述

然后我们用gcc编译生成一个可以供我们调试的二进制文件“Feb5”
在这里插入图片描述
之后就全是GDB要做的工作了。

gdb <二进制文件名>: 开始调试在这里插入图片描述

gdb中运行list命令(缩写l)可以列出代码
① list / l <行号>显示改行附件的10行代码;
② list / l <函数名> 显示函数名为“ ”的函数的代码;
在这里插入图片描述
run / r : 运行程序;
在这里插入图片描述
程序正常退出,并且输出出了第五个斐波那契数为“5”;

断点设置:

① break / b <行号> : 在某一行设置断点;
② break / b <函数名> :在该函数开头设置断点;
③ info break / i b :查看断点信息;
④ delete <断点序号> : 删除断点;
⑤ disable <断点序号> : 使该断点失效;
⑥ enable <断点序号> : 使该断点生效。
在这里插入图片描述
使断点失效并不会删除断点,我们使2号断点失效后,2号断点的“Enb”由“y”变为“n”;

next / n : 逐过程执行,这相当于VS里面的F10;

step / s : 逐语句执行,相当于VS里面的F11;
print / p <变量名/表达式> : 打印变量或表达式的值
continue / c : 从当前位置开始连续而非单步执行;
我们删除上面的所有断点,然后重新设置断点然后执行程序。
在这里插入图片描述
退出调试 : quit / q;

调试Coredump文件(崩溃文件或内存镜像)

举一个简单的例子:

在这里插入图片描述

在这里给空指针赋值,肯定会报错。

在这里插入图片描述
然后编译执行,
这里报了个Segmentation fault,意思是段错误,暨访问空指针或者内存越界。
我们先查看当前环境下能否支持产生内存镜像文件,条件为:
①Linux操作系统当中需要设置core size 的大小,ulimit -c 查看core file size的空间大小,默认为0,意思是无论任何情况下都不产生内存镜像文件,键入命令ulimit -c unlimited,即解除限制。(软限制)
②磁盘大小充足。(硬限制)

再次执行该文件:

在这里插入图片描述
产生内存镜像文件。该文件保存的是程序在崩溃时内存当中的值。
开始调试:
gdb <可执行文件> <内存镜像文件名>
在这里插入图片描述
程序收到11号信号,产生段错误。也报出了导致程序崩溃的代码行。
第6行 *p = ‘a’;解引用崩溃,暨可能给空指针赋值,或野指针,
在这里插入图片描述
打印被解引用的指针,0×0即为空指针。

转载地址:http://vjzaz.baihongyu.com/

你可能感兴趣的文章
MySQL - 4种基本索引、聚簇索引和非聚索引、索引失效情况、SQL 优化
查看>>
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>