gdb调试器可以通过将断点的设置与相应的操作结合起来,就可以尝试修改程序(也称为打补丁)而不需要改变程序源代码并重新编译。
#include <stdio.h>
Int main()
{
Int a=0;
if(a==1)
{
printf(“a=%d\n”,a);
printf(“set success\n”);
}
else
{
printf(“a=%d\n”,a);
}
}
将test.c编译:gcc –g test.c –o test
执行./test
程序输出:a=0
由test.c程序中可以看出,当程序进入if判断时,由于a始终为0,不会满足(a==1)的条件,因此程序不会执行符合条件(a==1)中的语句中。如果我们想测试(a==1)中的语句,一个可实现的方法是我们通过更改源代码,在if之前,添加一条语句:a=1; 然后重新编译,执行,边可以达到我们的效果。但是我们紧紧是测试而已,这样做显得繁琐,如果我们能过在调试的时候,直接让程序进入到满足条件(a=1)里的语句,那事情就显得简单了,而强大的gdb调试器满足了我们这个愿望,通过gdb打补丁方法便可以达到我们要的效果。
我们执行:gdb test
进入gdb调试节面,我们通过break和commands相结合操作,便实现了打补丁了。具体操作见下图。
上图中红色箭头指向的便是条件(a=1)中语句运行的结果。