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