在前几讲中,在讲解了断点的基本用法后,给大家介绍了简单的关于变量监视的技术,包括运行中的局部变量监视,也打开了编译器监视的一小扇门,今天将为大家讲解更全面的窗口监视。如下:
1.内存监视
除了我们之前讲的可以监视程序中的局部变量以外,我们还可以监视其他想要的信息,比如数组中某一元素的值,特定地址处的值等等。比如我们在学习字符串函数strcoy时,很多同学不明白函数的的”覆盖”效果,我们则可以通过内存监视来详细查看,例如程序:
#include<stdio.h>
int main()
{
char str1[100] = "www.dotcpp.com";
char str2[100] = "C language";
strcpy(str1,str2);
puts(str1);
return 0;
}
我们想查看strcpy函数过后str1数组中的值,而puts仅仅会显示覆盖后的,如果我们想看后面没有输出的字符,那么最好就要内存监视了,方法如下:
在puts函数处设断点,运行程序,如下:
我们可以在右下方处输入我们想要看的数组元素来查看未输出的那部分元素内容,如图:
也可以在内存监视框里,输入str1来查看str1数组在内存中的存储情况,如下图:
可以看到str1里的各字节处内容为何物,重要的是我们知道str1的真实内容为“C language.com”。
这下,是不是心里更有数了呢?
2.寄存器监视
寄存器的呼出窗口是View – Debug Windows – Registers 快捷键是Alt+5,我们可以通过这个窗口查看寄存器的数值变化情况,也可以结合汇编代码对比查询。
例如一个累加求和程序,通过断点监视寄存器观察如下:
可以看到变量i和sum在分别存放于EAX和ECX两个通用寄存器中。对于逆向学习也是很好的工具哦,方法是View – Debug Windows – Disassembly 对应快捷键Alt+8可以呼出反汇编代码,如下:
怎么样,方便吧
3.栈回溯
我们在学习函数调用,以及C程序的真正入口 函数时就可以利用VC6编译器提供的栈回溯功能,来查看函数调用过程,方法是在调试环境下选择View – Debug Windows – Call Stack 快捷键Alt+7例如我们写一个例子程序,可以尝试此功能:
可以看到add函数之前是main函数调用,再之前… …
怎么样,看到这几个功能,是不是对VC6的掌握更深了呢?