Ubuntu下GDB调试器的使用

Wesley13
• 阅读 856

gdb调试器时一款GNU组织开发、发布的UNIX/Linux环境下的程序调试工具,没有图形界面,但功能强大。

GDB使用流程:

先编写一个测试文件gdbTest.c

Ubuntu下GDB调试器的使用

       保存后用gcc对文件进行编译,需要加上 -g 参数,否则不能使用gdb进行调试。

   gcc gdbTest.c -o gdbTest -g

Ubuntu下GDB调试器的使用

  1. 查看文件

       在gdb中键入“l”(list)就能够查看载入的文件。

Ubuntu下GDB调试器的使用

       在不输入其他参数的情况下l 打开的是包含main()函数的文件,如果要打开其他文件可以在l 后面输入文件名作为参数。

       也可以定位到某个文件下的某个函数的位置,使用的方式是在文件名后面再附加一个函数名字符串,例如:

l gdbTest.c:sum

  1. 设置断点

       设置断点的方式是输入b(或者 break) 行号,例如再gdbTest.c中的第6行和第21行分别设置一个断点,我们可以:

       b 6

       b 21

Ubuntu下GDB调试器的使用

       除了普通断点以外,还可以设置条件断点:

              b 22 if i==10

Ubuntu下GDB调试器的使用

  1. 删除断点

       使用命令 d + 断点号 可以删除指定的断点

  1. 查看断点

       在设置完断点后还可以查看断点信息:

              info b

Ubuntu下GDB调试器的使用

  1. 运行代码

       在gdb中运行代码可以使用 start 命令。

Ubuntu下GDB调试器的使用

       运行过程中遇到断点就会停下来。

       继续执行输入命令             c(Continue)

       执行下一步输入命令          n(Next)

       继续执行输入命令             r(Run)

       进入函数体输入命令          s (Step)

       跳出循环使用命令             u

       跳出当前函数使用命令      finish

  1. 查看变量值

       查看变量的值可以使用命令p + 变量名

       p i

       追踪变量的值可以使用命令 display + 变量名

       display i

info display 命令可以查看到追踪的变量的信息

使用命令 undisplay + 变量名可以停止追踪某个变量

  1. 查看变量类型

       使用命令type + 变量名 可以查看变量的类型

  1. 设置变量的值

       使用命令 set var + 变量名 = 值 可以直接设置某个变量的值。

  1. 退出gdb

       使用命令 quit 可以退出gdb

GDB基本命令:

       gdb的命令可以通过help进行查找,因为gdb的命令非常多,所以gdb的help将其分成了很多种类(class),用户可以通过进一步查看相关的class找到相应的命令。

  1. 工作环境相关命令

       set args[运行时参数]

              指定运行时参数,如:set args 2

       show args

              查看设置好的运行参数

       path dir

              设定程序的运行路径

       show paths

              查看程序的运行路径

       set environment var[=value]

              设置环境变量

       show environment [var]

              查看环境变量

       cd dir

              进入dir目录,相当于shell中的cd命令

       pwd

              显示当前工作目录

       shell command

              运行shell的command命令

  1. 设置断点于恢复命令

       info

              查看所设断点

       break[文件名:]行号或函数名 <条件表达式>

              设置断点

       tbreak[文件名:]行号或函数名 <条件表达式>

              设置临时断点,到达后被自动删除

       delete [断点号]

              删除断点

       disable [断点号]

              停止指定断点,不等同于删除,可以被恢复

       enable [断点号]

              激活指定断点,被disable的断点

       condition [断点号] <条件表达式>

              修改对应断点条件

       ignore [断点号] num

              忽略断点num次

       step

              单步恢复程序,并进入函数调用

       neat

              单步恢复程序,不进入函数调用

       finish

              运行程序,直到当前函数完成返回

       c

              继续执行,直到函数结束或遇到新断点

  1. gdb中源码查看相关命令

       list <行号>|<函数名>

              查看指定位置代码

       file [文件名]

              加载指定文件

       forward-search 正则表达式

              源代码的前向搜索

       reverse-search 正则表达式

              源代码的后向搜索

       dir DIR

              将路径DIR添加到源文件搜索路径的开头

       show directories

              显示源文件的当前搜索路径

       info line

              显示加载到gdb内存中的代码

  1. gdb中查看运行数据相关命令

       print 表达式|变量

              查看程序运行时对应表达式或变量的值

       x <n/f/u>

              查看内存变量内容,n为整数表示显示内存长度,f表示显示的格式,u表示从当前              地址往后请求显示的字符数

       display 表达式

              设定单步运行或其他情况中,自动显示的对应的表达式的内容

       backtrace

              查看当前栈的情况,既可以查到哪些被调用的函数尚未返回

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
Java获得今日零时零分零秒的时间(Date型)
publicDatezeroTime()throwsParseException{    DatetimenewDate();    SimpleDateFormatsimpnewSimpleDateFormat("yyyyMMdd00:00:00");    SimpleDateFormatsimp2newS
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
2年前
HIVE 时间操作函数
日期函数UNIX时间戳转日期函数: from\_unixtime语法:   from\_unixtime(bigint unixtime\, string format\)返回值: string说明: 转化UNIX时间戳(从19700101 00:00:00 UTC到指定时间的秒数)到当前时区的时间格式举例:hive   selec
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这