引言 - 程序调试的痛
调试是程序员逃脱不了的宿命!
Linux上,有人喜欢GDB,有人喜欢简单粗暴的printf。很难说哪个好,哪个不好,两者各有各的优势和不足,大多时候是可以互补的。
printf最大的不足,就是需要修改代码,重新编译,重新部署。而程序调试本身是个复杂的工作,很多时候需要不断重复这些步骤,这就导致问题定位效率非常低。而且,当问题定位出来之后,还要花不少精力,把这些调试信息全部删掉!
对于简单的程序,这些尚可接受。但是,在大型项目中,单是编译构建过程可能就要几十分钟,甚至数个小时,而部署过程则更为复杂。你能想象得出,在这样的项目中一直重复这些过程,是一件多么痛苦的事情吗?
那么,有没有一种方法,既不需要修改源码,又能随时在程序中任何地方任意添加打印信息呢?
当然有!GDB的动态打印功能正式为此而生的!
GDB Dynamic Printf
GDB提供了Dynamic Printf功能,下文我们称之为动态打印。利用这个功能,我们可以在不修改程序源码的情况下,随时在程序的任何地方添加格式化打印。
如此一来,当然也就不需要重新编译和部署的过程了。
我们先看一个简单的示例,然后再详细介绍它的实现原理,和相关命令的用法。
示例
一个简单示例,如下图所示:
int main(int argc, char *argv[])
{
int i, a, b;
a = 1;
b = 2;
for(i = 0; i < 5; i ++)
{
a = a + i;
b = a * 2;
}
return 0;
}
先编译一下:
gcc -g test.c -o test
然后用GDB进行调试: