关于函数调用中堆栈维护的原理

                                           关于函数调用中堆栈维护的原理

 

1.每个函数调用的栈帧组成 old ebp 、寄存器信息、局部变量、函数入参、调用的返回地址

2.需要注意的是,帧栈每次操作push 或者是 pop 帧指针esp 都会自动自减或者是自增

2.每次调用函数之前都有下面的汇编操作

push ebp

mov esp ebp

所以ebp指针指向的是,每个函数帧栈push ebp 之后的地址,old ebp保存的是上一层函数调用的栈帧的基地址

3.返回,在函数调用返回之前,都会有下面的汇编操作

mov ebp esp

pop %ebp

这两句话的意思是把ebp的地址值赋值给esp,相当于把esp回退值ebp处;在当前的esp地址上,pop一个值,赋值给ebp,其实就是把ebp指针回退到上一个函数调用的基地址。

pop操作之后,esp指针会回退至这个函数调用时候的栈顶处,也就是上一个函数调用的末尾处,与此同时ebp指向了上一个函数调用的栈帧的的基地址。

4.依次类推,直至全部函数调用返回。

5.理解的关键是栈帧的结构,以及ebp具体的位置是在哪里,这点很关键。