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

                                           

 

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具体的位置是在哪里,这点很关键。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值