esp和ebp有什么区别

= 问题 =
  pushl %ebp
movl %esp,%ebp
干嘛要这样? 
 

--------------------------------------------------------------------------------
  esp是堆栈指针 
ebp是基址指针 

那两条指令的意思是 将栈顶指向 ebp 的地址 
--------------------------------------------------------------- 

楼主写的好像是要用GCC来编译的汇编? 

以下摘自我的一篇文章: 

push    ebp             ;ebp入栈 
mov     ebp, esp        ;因为esp是堆栈指针,无法暂借使用,所以得用ebp来存取堆栈 
sub     esp, 4*5        ;下面的wsprintf一共使用了5个参数,每个参数占用4个字节,所以要入栈4*5个字节 
push    1111 
push    2222 
push    3333 
push    offset szFormat 
push    offset szOut 
call    wsprintf        ;调用wsprintf 
add     esp, 4*5        ;堆栈使用完毕,“还”回4*5个字节给系统 
... 
mov     esp, ebp        ;恢复esp的值 
pop     ebp             ;ebp出栈 
ret 


明白了吗?主要是用来保存/恢复堆栈,以便传递参数给函数。 
在MASM里面,有一条更方便的语句,就是invoke 
使用它后,你就不用自己做这些事情了。 


--------------------------------------------------------------- 

esp始终指向栈顶,ebp是在堆栈中寻址用的
 

你可能感兴趣的:(汇编基础)