初识GDB

GDB的定义

Linux 包含了一个叫 gdb 的 GNU 调试程序. gdb 是一个用来调试 C 和 C++ 程序的强力调试器. 它使你能在程序运行时观察程序的内部结构和内存的使用情况. 以下是 gdb 所提供的一些功能:
1、它使你能监视你程序中变量的值.
2、它使你能设置断点以使程序在指定的代码行上停止执行.
3、它使你能一行行的执行你的代码.
在命令行上键入 gdb 并按回车键就可以运行 gdb 了

GDB的功能以及对应的命令

以下是较为常用的部分GDB命令和功能:

命令形式功能解释示例(gdb)
GDB进入gdb调试GDB
help显示帮助信息help
quit退出GDB调试q(quit)
file 加载被调试的可执行程序文件(文件是经过编译之后形成的可执行文件,在编译时,应该加上-g 选项,比如 gcc -o test_gdb test_dgb.c -g)file test_gdb
list列出文件的内容l (list)
run运行调试的程序(如果程序中没有设置断点,则程序会一直运行到结束或者出现异常结束,如果设置断点,则会在断点处停止)r(run)
next单步调试n(next)
delete 删除断点编号对应的断点d(delete) 1
clear清空所有的断点信息clear
step遇到函数调用时,进入函数内部调试s(step)
continue继续执行程序直到下一个断点或者程序结束c(continue)
print 显示变量的值p(print) index
info <>用来显示各类信息,详细请查看“help info”i(info) break

调试过程

首先第一步:
对源程序进行编译,加上-g选项,使其可以进行调试。其结果是生成可执行文件test_gdb,并且可以对其进行gdb调试。在这里插入图片描述
第二步:进入gdb在这里插入图片描述
第三步:调用可执行文件在这里插入图片描述
第四步:输入r运行程序在这里插入图片描述
预览程序的内容,以便于设置断点在这里插入图片描述
第五步:设置断点在这里插入图片描述
第六步:调试运行

输入r开始运行,在第一个断点处(即main函数入口)停止运行。
输入n执行下一步,此时再次打印输出num1,即可完成初始化。(如不初始化,num1的值就是随机值)
在这里插入图片描述
当程序执行到getSum函数的调用处时,执行s,进入到getSum函数内部,继续调试执行。
在这里插入图片描述
一直进行单步调试,直到函数结束运行,退出函数的调用
最后:
在getSum函数结束之前以及结束之后分别打印输出sum值:
在这里插入图片描述
在这里插入图片描述
结果表明,函数sum完成了num1和2的求和运算并且对sum进行赋值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕业设计,基于SpringBoot+Vue+MySQL开发的公寓报修管理系统,源码+数据库+毕业论文+视频演示 现代经济快节奏发展以及不断完善升级的信息化技术,让传统数据信息的管理升级为软件存储,归纳,集中处理数据信息的管理方式。本公寓报修管理系统就是在这样的大环境下诞生,其可以帮助管理者在短时间内处理完毕庞大的数据信息,使用这种软件工具可以帮助管理人员提高事务处理效率,达到事半功倍的效果。此公寓报修管理系统利用当下成熟完善的Spring Boot框架,使用跨平台的可开发大型商业网站的Java语言,以及最受欢迎的RDBMS应用软件之一的MySQL数据库进行程序开发。公寓报修管理系统有管理员,住户,维修人员。管理员可以管理住户信息和维修人员信息,可以审核维修人员的请假信息,住户可以申请维修,可以对维修结果评价,维修人员负责住户提交的维修信息,也可以请假。公寓报修管理系统的开发根据操作人员需要设计的界面简洁美观,在功能模块布局上跟同类型网站保持一致,程序在实现基本要求功能时,也为数据信息面临的安全问题提供了一些实用的解决方案。可以说该程序在帮助管理者高效率地处理工作事务的同时,也实现了数据信息的整体化,规范化与自动化。 关键词:公寓报修管理系统;Spring Boot框架;MySQL;自动化;VUE
毕业设计,基于SpringBoot+Vue+MySQL开发的社区医院管理系统,源码+数据库+毕业论文+视频演示 信息数据从传统到当代,是一直在变革当中,突如其来的互联网让传统的信息管理看到了革命性的曙光,因为传统信息管理从时效性,还是安全性,还是可操作性等各个方面来讲,遇到了互联网时代才发现能补上自古以来的短板,有效的提升管理的效率和业务水平。传统的管理模式,时间越久管理的内容越多,也需要更多的人来对数据进行整理,并且数据的汇总查询方面效率也是极其的低下,并且数据安全方面永远不会保证安全性能。结合数据内容管理的种种缺点,在互联网时代都可以得到有效的补充。结合先进的互联网技术,开发符合需求的软件,让数据内容管理不管是从录入的及时性,查看的及时性还是汇总分析的及时性,都能让正确率达到最高,管理更加的科学和便捷。本次开发的社区医院管理系统实现了病例信息、字典表、家庭医生、健康档案、就诊信息、前台、药品、用户、用户、用户表等功能。系统用到了关系型数据库中王者MySql作为系统的数据库,有效的对数据进行安全的存储,有效的备份,对数据可靠性方面得到了保证。并且程序也具备程序需求的所有功能,使得操作性还是安全性都大大提高,让社区医院管理系统更能从理念走到现实,确确实实的让人们提升信息处理效率。 关键字:社区医院管理系统;信息管理,时效性,安全性,MySql
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值