<2011年5月>
24252627282930
1234567
891011121314
15161718192021
22232425262728
2930311234

统计

  • 随笔 - 1
  • 文章 - 0
  • 评论 - 0
  • 引用 - 0

常用链接

留言簿

随笔分类

随笔档案

搜索

  •  

最新评论

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文档上有一个图片画错了。。。这个很纠结。。。

posted on 2011-05-22 09:58 凝霜 阅读(677) 评论(0)  编辑 收藏 引用


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理