esp和ebp指针

Posted zhazhalovecoding

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了esp和ebp指针相关的知识,希望对你有一定的参考价值。

gdb调试的时候会出现esp和ebp这两个指针,而这两个指针为我们查看栈的情况提供了方便。

简单点说,esp指向栈顶,而ebp指向栈底。例如一段程序:

 1 #include <stdio.h>
 2 
 3 int layout(int a){
 4     int b = a + 5;
 5     return b;    
 6 }
 7 
 8 int main(void){
 9     int a = 5;
10     layout(5);
11 
12     return 0;      
13 }
View Code

执行过程中esp和ebp的状态如下:

 

这时执行main函数中调用layout之前的栈的状态。调用layout时栈的状态如下:

所以,esp和ebp指向当前执行函数的栈顶和栈底,这也是每次调用函数时我们需要保存ebp的原因。esp不用保存,A调用B时,A的栈顶就是B的栈底。

以上是关于esp和ebp指针的主要内容,如果未能解决你的问题,请参考以下文章

汇编中EBP寄存器和ESP寄存器的区别

esp寻址ebp寻址

寄存器简介 与 ebp esp

_stdcall 函数 debug/release汇编代码区别

EBP循址

课程学习总结报告