gdb基本使用

拖欠很久的gdb入门说明笔记,今天写一下,主要脑子不太好使,学一遍就忘,记一下。零零散散写一些,随便打打应该够了。

一.编译部分

​ 用gcc编译的时候需要记得给一个-g的参数,不然后面调不了

image-20240607192310589

​ 直接gdb -q test关掉版本信息,OK,gdb启动!

image-20240607192945947

​ 如果不给-g的参数的话是这样的,没有调试的符号信息,就用不了gdb了,可怕不可怕

image-20240607193136461

二.基本使用

​ 1.先list一下看看源码,默认显示前几行,回车继续往下看,这边就写了6行的helloworld哈哈哈

image-20240607193323948

​ 2.r直接运行程序,遇到结束则退出,断点的话就等待下一条命令

image-20240607193602207

​ 3.程序没有断点,给它打个断点试试看,break(简写 b) :格式 b 行号,在某行设置断点,b 3一下之后直接info breakpoints查看一下断点信息,然后再run一下看看捏

image-20240607194402520

image-20240607194434522

​ 为森莫他们都断在了第四行呢,因为我第三行压根没东西hhh,断点信息各部分如下:

1
2
3
4
5
6
7
break(简写 b) :格式 b 行号,在某行设置断点;
info breakpoints :显示断点信息
Num: 断点编号
Disp:断点执行一次之后是否有效 kep:有效 dis:无效
Enb: 当前断点是否有效 y:有效 n:无效
Address:内存地址
What:位置

三.断点命令集合

run:简记为 r ,其作用是运行程序,当遇到断点后,程序会在断点处停止运行,等待用户输入下一步的命令。
continue (简写c ):继续执行,到下一个断点处(或运行结束,类似f9
next:(简写 n),单步跟踪程序,当遇到函数调用时,也不进入此函数体;此命令同 step 的主要区别是,step 遇到用户自定义的函数,将步进到函数中去运行,而 next 则直接调用函数,不会进入到函数体内。(类似f8)
step (简写s):单步调试如果有函数调用,则进入函数;与命令n不同,n是不进入调用的函数的(类似f7)
until:当你厌倦了在一个循环体内单步跟踪时,这个命令可以运行程序直到退出循环体。
until+行号: 运行至某行,不仅仅用来跳出循环
finish: 运行程序,直到当前函数完成返回,并打印函数返回时的堆栈地址和返回值及参数值等信息。
call 函数(参数):调用程序中可见的函数,并传递“参数”,如:call gdb_test(55)
quit:简记为 q ,退出gdb

四.查看变量

使用print、whatis命令,print打印的为变量中存放的数据,而whatis打印的是该变量的类型,逐渐熟悉动调!

image-20240607201217704