1.gdb -x command.txt
每次重复输入命令很麻烦,可以使用上面的命令,把命令输入进command.txt里面,然后直接就可以执行gdb。
2.list
2.1 list function 打印function源程序
2.2 list line1,line2 打印从line1到line2的程度
3.断点
查看当前断点信息: info b
4找到一个函数的入口地址
首先,找到函数在第几行:lise function
info line 行号
方法二:用objdump生成符号表,通过符号表来知道
objdump -t example >symbol.txt
5.查看程序栈帧的调用
bt
显示的是当前栈帧调用,如:
这个表示当前程序总共维护三个栈帧,从下往上看,首先,程序第一个进入的是main函数,然后再454行的位置调用了launch函数,在launch中,调用了test函数,而test就是当前程序正在执行的地方。=
上面最左边的编号就是栈所对应的的栈框,如果要选中某一个栈,要输入命令
frame NUM
如frame 2
选中了main函数的栈框
如果需要更加详细的信息,就要使用
info f
得到的详细栈帧信息:
包括各种寄存器的地址,通过这些,就可以来跟踪函数的栈帧。
rip是程序指令的指针,指向吓一跳要执行的指令。