注册 登录
编程论坛 汇编论坛

请问下WIN32里面的EBP是什么寄存器?

honker 发布于 2008-07-02 16:51, 3371 次点击
是不是和ESP一样的?
比如 mov eax,SS:ESP和mov eax,SS:EBP是不是一样的意思?只是分别在不同的2个堆里?
4 回复
#2
zklhp2008-07-03 21:12
好象不是吧
#3
perfy2008-07-03 22:35
不是一样的,sp是存栈的栈顶偏移地址,bp是存栈的某个变量的偏移地址,一般都跟堆栈指针一起用...
#4
ONEPROBLEM2008-07-14 11:17
EBP一般和ESP配合使用,作用很大啊。
比如,子程序的开头往往这样子的:
push  ebp
mov   ebp,  esp
add   esp,FFFFFFF8     ;预留局部变量存储空间
... ...
先保存EBP最原先的值入栈,然后把当前的ESP的值赋给EBP,以后通过[EBP-XX]或[EBP+XX]就可以引用堆栈中的任何地方的值了。如,通过[EBP-XX],得到子程序中的局部变量,通过[EBP+XX],得到子程序的参数,等等。
在恢复堆栈的时候,EBP和ESP的配合使用,就更容易恢复了:
mov   esp,ebp
pop   ebp
在汇编中,往往用leave这条指令就实现这两条指令的功能了。
#5
missiyou2008-07-14 22:59
其实这个ebp 之所以入栈,相当于保存一页纸,下面使用就等使用新的一页。
1