下面三个网页,讲解了基本的gdb用法。
https://blog.csdn.net/Z_Dream_ST/article/details/77840733###
http://www5.zzu.edu.cn/qwfw/info/1041/2414.htm
https://blog.csdn.net/xiongxinlei/article/details/78200275
额外,基本的
p *this 输出当前堆栈的信息
set args {args}
# 这里的{args}代表bin文件的输入信息
set directories {args}
# 这里的{args}是指代码路劲
gdb {bin}
# 这里的{bin}文件即是基本的bin文件。
b {file:25}
# {file:25} 这里是指在file的25行加上断点。
delete break n
# 删除当前文件对应的断点
delete break
# 删除所有断点,这个待测试
下面介绍基本的用法:
调试程序通常有两种基本的调试方法:
·断点调试:设置断点进行执行、观察断点的执行状态
·单步调试:每执行一个语句就暂停、观察语句运行情况
使用run命令(支持简单输入r形式)开始执行程序,如果遇到断点就会暂停,否则继续执行。程序暂停后,从断点继续执行后续代码,需要使用cont命令(或输入c)。kill命令停止程序执行。
单步执行就是执行一条语句后再次暂停(不必为此设置断点),主要有两条命令:
next N # step over,单步执行语句,不进入子程序(函数)调试、直接调用完成
step N # step into,跟踪执行语句,进入子程序(函数)当中进行调试(但不会进入没有调试信息的子程序当中,包括系统功能调用、标准函数等)
finish # step out,执行完成当前函数
如果指明参数N,则表示执行N条指令后暂停。对应单步执行语句命令step和next,还有单步执行指令命令stepi和nexti。高级语言的一条语句可以由许多机器指令组成,但汇编语言中一个语句通常就是一个机器指令。所以进行汇编语言级调试,step和stepi,next和nexti是一样的。