逆向工程-函数序言和函数尾声
Posted 小蚂蚁_CrkRes
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了逆向工程-函数序言和函数尾声相关的知识,希望对你有一定的参考价值。
函数序言(function prologue)
是函数在启动的时候运行的一系列指令。
push ebp
mov ebp,esp
sub esp,X
这些指令的功能是:在栈里保存EBP寄存器的内容、将ESP的值复制到EBP寄存器,然后修改栈的调试,以便为本函数的局部变量申请存储空间。
在函数执行期间,EBP寄存器不受函数运行的影响它是函数访问局部变量和函数参数 的基准值。虽然我们也可使用ESP寄存器存储局部变量和运行参数,但是ESP寄存器的值总是变化的,使用起来不方便。
函数尾声
函数在退出时,要做启动过程的反操作,释放栈中的申请内存,还原EBP寄存器的值,将代码控制权还原给调用者函数
mov esp,ebp
pop ebp
ret 0
递归调用
函数序言和尾声都会调整数据栈受硬件IO性能影响,所有递归函数的性能都不太理想。
以上是关于逆向工程-函数序言和函数尾声的主要内容,如果未能解决你的问题,请参考以下文章