关于帧指针和栈指针的定义

时间:2024-03-18 17:07:29

关于栈帧结构,先引用网上的一张图:

关于帧指针和栈指针的定义

栈的增长方向是向下的。栈有个最大地址,这个地址成为栈底,也是存储栈里面存储第一个元素的位置,随着入栈个数增加,栈顶的地址不断减小。

esp寄存器就是专门用来存储栈顶地址的,而栈指针便指向栈顶。


函数调用时的内存布局:

|-----参数----------|

|---返回地址--------|

|----旧的ebp--------| 新的ebp(帧指针)就会指向这里

|---保存的寄存器状态|

|--本地变量---------|

所以当前ebp-4就是返回地址,当前ebp-8就是调用传来的参数。


相关文章