1,启动gdb的时候自动执行脚本
gdb -x your_script
注意:your_script里面只能有gdb命令。不过我们都知道gdb命令里面有个shell指令,所以实际上这里可以做任何事。
2,调试运行中的进程
在gdb里面有个attach指令,可以调试运行中的进程。
结合上面的-x参数,实际上我们可以写一个脚本,自动的attach到我们关心的进程上面,然后自动的做很多事情:比如设置trace命令并且continue。
3,设置条件断点
break test_func() if x == 5
可以在x == 5 的时候中断在test_func()里面
4,在断点自动执行命令
break test_func() if x == 5
commands
>shell ls
>continue
>end
可以在命中断点的时候自动执行命令。
5,结合以上各点,我们可以做什么呢?
我们可以调试运行中的一个进程,当发现进程尝试mallc()超过100KB的内存块的时候,就写一行日志然后给ops发一封电子邮件。
我们还可以调试运行中的一个进程,让这个进程把它的每个细节都打印到日志里面去。
我们可以让这个运行中的进程,在任何条件下执行任何他自己的任何函数。
我们可以让这个运行中的进程,进行各种跳转。
简单的说我们可以控制这个进程,做任何事情。
这基本上是一个C++版的AOP(面向切面编程)了。而且更底层、更彻底。