关于栈帧结构,先引用网上的一张图:
栈的增长方向是向下的。栈有个最大地址,这个地址成为栈底,也是存储栈里面存储第一个元素的位置,随着入栈个数增加,栈顶的地址不断减小。
esp寄存器就是专门用来存储栈顶地址的,而栈指针便指向栈顶。
函数调用时的内存布局:
|-----参数----------|
|---返回地址--------|
|----旧的ebp--------| 新的ebp(帧指针)就会指向这里
|---保存的寄存器状态|
|--本地变量---------|
所以当前ebp-4就是返回地址,当前ebp-8就是调用传来的参数。