esp,ebp,push,pop

本文探讨了内存中栈和堆的生长方向及其理论上的空间利用,栈从高地址向低地址生长,而堆则相反。在函数调用过程中,通过将调用者帧底压栈并建立新帧来管理栈空间。同时,文章提及push操作的实现方式以及ebp和esp寄存器的角色。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

看完就忘系列……记一下……

在内存中,栈和堆分别从高地址和低地址相向生长,理论上是为了空间的有效利用,因为栈用的少了,堆就可以用的多点,反之亦然(当然如果两个碰头了怎么办?谁知道……)

栈从高地址向低地址生长,栈(帧)顶esp浮动,而栈(帧)底ebp固定。在进行push操作时,先esp=esp-8;再data->(esp)。

在函数调用时,先将调用者帧底(ebp)压栈,然后建立新的帧,即将当前帧顶(esp)赋予帧底(ebp)(mov %esp,%ebp;)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值