esp寻址ebp寻址
Posted uestc2017zh
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了esp寻址ebp寻址相关的知识,希望对你有一定的参考价值。
栈顶指针esp 栈底指针ebp
esp寻址
构建函数
1.使用寄存器传递参数
2.使用堆栈来传递参数
push 1
push 2
push 3
把要用的参数压入堆栈后,需要用call调用函数来计算参数,调用call时,会将call的下一行指令的地址压入栈中,所以使用参数时地址为[esp+4,8,12]
使用函数的代码为 mov eax,ptr ss:[esp+4]
add eax,ptr ss:[esp+8]
add eax,ptr ss:[esp+12]
retn 12 //保持堆栈平衡
在函数中,需要使用寄存器时,最好将原来寄存器的值保存在堆栈中,使用完后,倒序pop回来
ebp寻址
在一个函数中重新分配栈空间给这个函数使用,使用完恢复为原来的栈
push 1
push 2
call 函数
……
push ebp
mov ebp,esp
mov esp,10 //10为十六进制,决定于实际需要的栈的大小
mov eax,ptr ss:[ebp+8]
add eax,ptr ss:[ebp+C]
mov esp,ebp
pop ebp
ret
以上是关于esp寻址ebp寻址的主要内容,如果未能解决你的问题,请参考以下文章
存储器 间接 寻址 试验 立即寻址 ;直接寻址 ;间接寻址 16位指针间接寻址 32位指针间接寻址