各位专家,请教一个问题:我在函数中申请了多个变量,通过单步执行发现某个变量在watch中看到的地址和sp寄存器+偏移地址对不上。我举例说明:
int test(char * description)
{
int a = 0,b=0,c=0;
int d= 5;
int e=0,f =0;
char* mod=Null;
int* ver =Null;
… //定义其他变量
//以上都是定义变量代码
test1(&d);//第一个执行语句
…
}
具体现象:
我从主函数call test 函数,在test函数中单步执行,假设汇编指令中看到给前三个a,b,c的地址esp+4,esp+8,esp+12;给d分配的是esp+16,并进行初始化,后面的变量地址就不在细数。
我单步到调用test1函数前,在watch中看到d的地址是b在stack中的(esp+偏移8)也就是b=5。
这种现象是为什么呢?在进入这个函数栈空间及时被人使用了也没有影响吧?