要理解函数调用堆栈的过程,首先要对汇编指令和寄存器有一定的了解。我们简单介绍几个:
寄存器
- ebp:保存栈底指针的地址
- esp:保存栈顶指针的地址
- pc:存储下一行指令的地址
- eax,ebx:保存变量的值
汇编指令
- mov :移值
- lea:移地址
- rep stos 循环拷贝
在进入一个函数的时候,系统首先会为主函数开辟一段栈帧空间,空间开辟的大小一般为十六进制的4c但也不是国定不变的,主要取决于定义变量的所需内存大小。首先把ebp寄存器的值压栈,然后将ebp减去4c大小的空间赋给esp,再将其压栈这样,再内存中就有了一段大小为4c的主函数栈帧空间开始执行主函数中的指令
当执行到一个函数的调用处时,会重复上面的过程,要注意这里首先是传参而不是给被调用函数开辟zhan栈帧空间,传递参数的值时,如果参数类型是内置类型也就是int,char,float等这些等这些基本类型时,直接用寄存器dai'带入,见上图,如果是自定义类型则会按照其类型的大小分为两种不同的情况,
- 如果其字节数大于8时,会在