关于函数调用中堆栈维护的原理
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具体的位置是在哪里,这点很关键。