在前期的学习中我们可能有很多困惑
例如:局部变量是怎么创建的
为什么局部变量的值是随机值
函数是怎么样传参的 传参的顺序是什么
形参和实参的关系是什么
函数调用是怎么做的
函数掉调用结束后怎么返回的
这篇博客我们来修炼自己的内功,掌握好这篇博客的大部分知识就已经很不错了
我们用到VS2013这个编译器,目的是为了看到更详细的函数封装内容
现在我们开始我们的正题
要想了解函数栈帧,首先我们要了解一下寄存器,寄存器有我们熟悉的eax ebx ecx edx
今天我们重点理解并掌握ebp esp这两个寄存器,这两个寄存器中存放的是地址,这两个地址是用来维护函数栈帧的
注意:先提醒一下大家,
每一个函数调用都要在栈区创建一个空间
现在我们写一个代码来观察一下
正在调用哪个函数我这个ebp esp就在维护哪个函数的函数栈帧,比如我F10调试起来进入main函数,这时我的esp ebp就在维护main函数的函数栈帧
其实在我们的VS2013中,main函数也是被其他函数调用的,那么是谁呢???
下面给大家画个图
下面我们接着走
push:压栈
move:移,放值
pop:出栈
sub:减
先看最开始的几个步骤
push:先在栈顶压一个ebp
move:把esp的值给了ebp(将地址传给ebp)
sub:给esp减去一个0E4h(八进制位数)这个值,减去一个0E4h的值后值变小了(地址变小了),那么此时ebp就指向了栈顶低地址
lea:load effective address(加载有效地址),ebp-0E4h就是再main函数的栈顶,为什么呢,这是因为我们前几个步骤在算的时候,esp在减去了一个0E4h之后就已经到达了栈顶,前面又把esp的值(地址)赋值给了ebp,所以理所当然的到达了栈顶,希望大家能够理解
再将ebx esi edi分别压栈压在栈顶