Linux复习之gdb调试举例

源程序如下,作用是通过调用函数输出1~10的和:
Linux复习之gdb调试举例_第1张图片
执行编译指令:gcc -o main main.c ,编译成功后,执行./main,程序显示结果result = 45
在这里插入图片描述
程序可以顺利的编译链接生成可执行文件,说明没有出现编译问题,但是可以看见,输出结果为134518459,明显错误。正确结果应该是55,下面利用gdb对程序进行调试,从而找到问题。
为了能够使用gdb调试,在由main.c编译链接生产可执行文件main时,命令行中必须加入选项-g。
具体步骤如下:
1.编译main.c,指令:gcc -o main main.c -g
在这里插入图片描述
2.使用gdb载入main,指令:gdb main
Linux复习之gdb调试举例_第2张图片
3.进入gdb环境后,使用命令“run“,运行main
在这里插入图片描述
发现结果是45,还是错误。
4.单步执行和跟踪函数。输入start命令开始进行gdb调试
Linux复习之gdb调试举例_第3张图片
可以看见程序停留在主函数result = add(1,10);
再次输入step命令,可以简写为s,追踪到函数add内进行查看,并使用backtrace,简写为bt,查看函数调用栈帧。
Linux复习之gdb调试举例_第4张图片
可以看见,主函数传递参数值start = 1,end = 10.add函数的栈帧编号为0,主函数的栈帧编号为1.
接下来利用info命令,简写为i,查看add函数中局部变量的值,如果想要查看主函数中局部变量的值,可以使用frame 1指令选择1号栈帧,再使用info来查看。
在这里插入图片描述
当前add函数中的变量i和sum都是随机值,sum = 134518404,这里就可以看出来为啥程序运行结果为134518459(sum = 134518404 + 55),所以找到了问题所在,错误是由于sum没有进行初始化而造成的。
当我们发现问题后,有两张方式进行修改:
第一种,采取在gdb命令行下对函数中的变量进行赋值,运行调试程序后进行验证,正确后再退出gdb修改源代码。
Linux复习之gdb调试举例_第5张图片
第二种,可以利用finishi命令让程序一直运行到从当前函数返回,或者使用continue命令程序运行到程序结束后修改代码。

你可能感兴趣的:(Linux复习)