各位看官们。大家好。上一回中我们说的是GDB改动程序执行环境的功能。而且说了怎样使用GDB改动变量
的值。这一回中。我们继续介绍GDB的调试功能:监视功能。当然了,我们也会介绍怎样使用GDB的监视功
能。闲话休提,言归正转。让我们一起talk GDB吧!
我们说的监视类似像电影中描写叙述的哪种监视。仅仅只是电影中的被监视对象一般是一些犯罪嫌疑人,而我们
的监视对象是执行着的程序,更详细点说。是程序中的存储单元地址。GDB提供了监视功能,首先设置一个
监视点,GDB会自己主动监视该监视点上的变化了,假设监视点发生了变化,GDB就会在监视点哪里停下来,这
时候,我们就能看到是谁让监视点发生了变化。我来总结一下详细的步骤:
1.设置一个监视点。样例:watch giVal 该样例表示在giVal所在的存储单元哪里设置一个监视点。
2.先使用start命令開始调试。当有程序改动监视点的存储单元时它就会停下来。
3.使用c命令会再次执行程序,直到有程序操作观察点监视的存储单元时再次停下来。
光说不练,不是我们的风格,接下来,我们用详细的样例来说明怎样使用监视功能。
#include<stdio.h> int g; void fun() { g = 3; } int main() { int a,b; a = 3; b = 5; g = a+b; printf("a+b = %d ",g); fun(); printf("a+b = %d ",g); return 0; }
1.编敲代码。打开VIM,输入上面的程序,而且保存到m.c文件里
2.编译程序。
在终端中输入:gcc -g m.c -o s
3.执行程序。在终端中输入:./s ,得到下面执行结果:
./s
a+b = 8
a+b = 3
大家能够看到程序中a=3,b=5,a+b=8这是小学生也会的数字呀。但是程序第一次输出运算结果时还正确,
第二次输出运算结果时就不对了,这是怎么回事?看官莫急,我们使用GDB的监视功能来调试一下。非常
快就能知道。
谁改动了这个全局变量。
在终端中输入:gdb s //使用GDB调试程序
(gdb) watch g //设置一个监视点。监视全局变量g
Hardware watchpoint 1: g
(gdb) start //開始调试
Temporary breakpoint 2 at 0x8048435: file m.c, line 13.
Starting program: xxx/s
Temporary breakpoint 2, main () at m.c:13
13 a = 3;
(gdb) c //继续调试程序,直到监视点g发生变化
Continuing.
Hardware watchpoint 1: g
Old value = 0 //这里显示监视点发生了变化,而且列出了变化前后的值
New value = 8 //这时的运算结果是正确的
main () at m.c:17
17 printf("a+b = %d ",g);
(gdb) c //运算结果正确。继续调试程序,直到监视点g发生变化
Continuing.
a+b = 8
Hardware watchpoint 1: g
Old value = 8 //这里显示监视点发生了变化,而且列出了变化前后的值
New value = 3 //g的值从8变成了3
fun () at m.c:8 //提示程序中第8行
8 }
(gdb) list 8 //观看程序中第8行的内容
3 int g;
4
5 void fun()
6 {
7 g = 3; //大家看到了吧,原来是fun函数改动了g的值。
8 }
9
10 int main()
11 {
12 int a,b;
(gdb) stop //结束调试
我们通过这个样例说明了怎样在调试过程中使用监视功能来调试程序,而且找出了错误发生的原因。只是
该样例比較简单,我们细致观察一下程序就能发现是fun函数改动了运算结果。
在实际的程序中,就不会
像样例中这么简单了。希望看官们可以举一反三。灵活使用监视功能调试程序。
监视功能也是GDB中一个十分强大的功能,在调试全局变量被改动,或者数组越界错误很实用。
会C语言
的看官们都知道,全局变量是C程序中一个十分让人头疼的东西,在有些程序中甚至不同意使用全局变量。
使用GDB的监视功能能够监视全局变量的一举一动,仅仅要全局变量发生了变化,它就会停止下来。因此可
以把监视功能看作是全局变量的克星。
看官们,关于GDB的内容,今天咱们就讲到这里。欲知后事怎样,且听下回分解!