enter 指令分析

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文檔上有一個圖片畫錯了。。。這個很糾結。。。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章