当调用函数时ip指向函数地址,函数都在堆栈中,这时ip的值等不等于sp,再说函数返回,恢复堆栈是不是回归原来的IP 求各位大神解答
2条回答 默认 最新
freedom_wings4 2016-07-18 14:39关注我觉得,调用函数后,会把调用前的指令的下一条指令地址压栈,再用push ebp, mov esb,esp,这样的,我觉得eip是不等于esp,另外函数本身的代码是不在栈中的。
返回时,因为入栈的是下一条指令的地址,所以会返回到call这些调用函数的指令的下一条指令的地址
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报