概述
enter指令分析
enter指令是为了支持高级语言中的变量作用于而加入的,它不是一个伪指令,但是却由于效率原因被各大编译器所摒弃,取而代之的是用多条指令去模拟来提升效率,确实是很悲哀的一个指令。。。
格式 ENTER reservedVarSize, level
reservedVarSize 局部变量占用内存的大小
level 嵌套的级别
当level = 0时,例如 enter x, 0
相当于
push ebp
mov ebp, esp
add esp, -x
而level != 0时,这个就是要说的关键
我们压到栈中的内容应该要保证能访问到访问级别更高的变量,那么我们就需要保存指向这些内容的栈帧的指针
例如
enter 10, 3
相当于
push ebp
mov ebp, esp
sub esp, (3 - 1) * 4
push ebp
sub esp, 10
第一步push ebp是上一嵌套级别的ebp,用来供leave指令返回到上一嵌套层
sub esp, (3 - 1) * 4这条指令是用来保存可访问的栈帧的指针,能访问几层就有几个
下面那条push ebp是保存当前栈帧的
最后sub掉esp,保存局部变量
看英特尔的文档纠结了很久,最后得出的结论就是intel文档上有一个图片画错了。。。这个很纠结。。。
最后
以上就是粗心鲜花为你收集整理的enter 指令分析的全部内容,希望文章能够帮你解决enter 指令分析所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复