青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

xiaoguozi's Blog
Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習慣原本生活的人不容易改變,就算現狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預料,人們需要更細心的觀察別人,要隨時注意才能保護別人,因為他們未必知道自己要什么·····
當調用(call)一個函數時,主調函數將聲明中的參數表以逆序壓棧,然后將當前的代碼執行指針(eip)壓棧,跳轉到被調函數的入口點。
        進入被調函數時,函數將esp減去相應字節數獲取局部變量存儲空間。被調函數返回(ret)時,將esp加上相應字節數,歸還棧空間,彈出主調函數 壓在棧中的代碼執行指針(eip),跳回主調函數。再由主調函數恢復到調用前的棧。
      
為了訪問函數局部變量,必須有方法定位每一個變量。變量相對于棧頂esp的位置在進入函數體時就已確定,但是由于esp會在函數執行期變動,所以將esp
的值保存在ebp中,并事先將原ebp的值壓棧保存,以聲明中的順序(即壓棧的相反順序)來確定偏移量。
訪問函數的局部變量和訪問函數參數的區別:
局部變量總是通過將ebp減去偏移量來訪問,函數參數總是通過將ebp加上偏移量來訪問。對于32位 變量而言,第一個局部變量位于ebp-4,第二個位于ebp-8,以此類推,32位局部變量在棧中形成一個逆序數組;第一個函數參數位于ebp+8,第二 個位于ebp+12,以此類推,32位函數參數在棧中形成一個正序數組。

      
函數的返回值不同于函數參數,可以通過寄存器傳遞。如果返回值類型可以放入32位變量,比如int、short、char、指針等類型,將通過eax寄存
器傳遞。如果返回值類型是64位變量,如_int64,則通過edx+eax傳遞,edx存儲高32位,eax存儲低32位。如果返回值是浮點類型,如
float和double,通過專用的浮點數寄存器棧的棧頂返回。如果返回值類型是struct或class類型,編譯器將通過隱式修改函數的簽名,以引
用型參數的形式傳回。由于函數返回值通過寄存器返回,不需要空間分配等操作,所以返回值的代價很低。基于這個原因,C89規范中約定,不寫明返回值類型的
函數,返回值類型默認為int。這一規則與現行的C++語法相違背,因為C++中,不寫明返回值類型的函數返回值類型為void,表示不返回值。這種語法
不兼容性是為了加強C++的類型安全,但同時也帶來了一些代碼兼容性問題。
代碼示例
VarType Func (Arg1, Arg2, Arg3, ... ArgN)
{
    VarType Var1, Var2, Var3, ...VarN;
    //...
    return VarN;
}
假設sizeof(VarType) = 4(DWORD), 則一次函數調用匯編代碼示例為:
調用方代碼:

push ArgN ; 依次逆序壓入調用參數
push ...
push Arg1
call Func_Address ; 壓入當前EIP后跳轉
跳轉至被調方代碼:
push ebp ; 備份調用方EBP指針
mov ebp, esp ; 建立被調方棧底
sub esp, N * 4; 為局部變量分配空間
mov dword ptr[esp- 4 * 1 ], 0 ; 初始化各個局部變量 = 0 這里假定VarType不是類
mov dword ptr[esp - 4 * ... ], 0
mov dword ptr[esp - 4 * N ], 0
. . . . . . ; 這里執行一些函數功能語句(比如將第N個參數[ebp + N * 4]存入局部變量), 功能完成后將函數返回值存至eax
add esp, N * 4 ; 銷毀局部變量
mov esp, ebp ; 恢復主調方棧頂
pop ebp ; 恢復主調方棧底
ret ; 彈出EIP 返回主調方代碼
接上面調用方代碼:
add esp, N * 4 ; 釋放參數空間, 恢復調用前的棧
mov dword ptr[ebp - 4], eax ; 將返回值保存進調用方的某個VarType型局部變量
進入函數時堆棧分配示意圖
內存低地址 | ESP - - - - - - - - - - - - - - - - EBP - - - - - - - - - - - - - - - - - - - - - >| 內存高地址
Stack State: VarN . . . Var3 Var2 Var1 SFP EIP Arg1 Arg2 Arg3 . . . ArgN
//資料
區...............................................................................................................................
SFP 解釋:      
除了堆棧指針(ESP指向堆棧頂部的的低地址)之外,
為了使用方便還有指向幀內固定地址的指針叫做幀指針(FP)。有些文章把它叫做局部基指針(LB-local base
pointer)。從理論上來說, 局部變量可以用SP加偏移量來引用。 然而, 當有字被壓棧和出棧后, 這些偏移量就變了。
盡管在某些情況下編譯器能夠跟蹤棧中的字操作, 由此可以修正偏移量, 但是在某些情況下不能。而且在所有情況下, 要引入可觀的管理開銷。
而且在有些機器上, 比如Intel處理器, 由SP加偏移量訪問一個變量需要多條指令才能實現。
        因此,
許多編譯器使用第二個寄存器, FP, 對于局部變量和函數參數都可以引用, 因為它們到FP的距離不會受到PUSH和POP操作的影響。
在Intel CPU中, BP(EBP)用于這個目的。 在Motorola CPU中,
除了A7(堆棧指針SP)之外的任何地址寄存器都可以做FP。考慮到我們堆棧的增長方向, 從FP的位置開始計算, 函數參數的偏移量是正值,
而局部變量的偏移量是負值。
      
當一個例程被調用時所必須做的第一件事是保存前一個FP(這樣當例程退出時就可以恢復這個被保存的FP稱為SFP)。 然后它把SP復制到FP,
創建新的FP, 把SP向前移動為局部變量保留空間。 這稱為例程的序幕(prolog)工作。當例程退出時, 堆棧必須被清除干凈,
這稱為例程的收尾(epilog)工作。 Intel的ENTER和LEAVE指令, Motorola的LINK和UNLINK指令,
都可以用于有效地序幕和收尾工作。
         所有局部變量都在棧中由函數統一分配,形成了類似逆序數組的結構,可以通過指針逐一訪問。這一特點具有很多有趣性質,比如,考慮如下函數,找出其中的錯 誤及其造成的結果:
void f()
{
int i,a[10];
for(i=0;i}
        這個函數中包含的錯誤,即使是C++新手也很容易發現,這是老生常談的越界訪問問
題。但是這個錯誤造成的結果,是很多人沒有想到的。這次的越界訪問,并不會像很多新手預料的那樣造成一個“非法操作”消息,也不會像很多老手估計的那樣會
默不作聲,而是導致一個死循環。
        錯誤的本質顯而易見,我們訪問了a[10],但是a[10]并不存在。C++標準對于越界訪問只是說“未定義操作”。我們知道,a[10]是數組a 所在位置之后的一個位置,但問題是,是誰在這個位置上。是i!
      
根據前面的討論,i在數組a之前被聲明,所以在a之前分配在棧上。但是,I386上棧是向下增長的,所以,a的地址低于i的地址。其結果是在循環的最后,


---------------------------------------------
原文的紅色esp感覺應該是ebp..
posted on 2010-07-01 09:07 小果子 閱讀(435) 評論(0)  編輯 收藏 引用 所屬分類: 學習筆記
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            麻豆91精品| 国产欧美精品一区aⅴ影院| 一区二区亚洲精品国产| 久久精品国产77777蜜臀| 亚洲一区二区毛片| 国产日韩欧美不卡在线| 久久大逼视频| 猛干欧美女孩| av成人免费在线| 亚洲视频在线观看网站| 国产欧美日韩一区| 麻豆国产精品777777在线| 欧美aa国产视频| 亚洲一区二区3| 欧美在线视频二区| 91久久精品国产91久久| 99视频+国产日韩欧美| 国产欧美日韩不卡| 免费日韩av电影| 欧美日韩亚洲91| 久久久久久亚洲综合影院红桃 | 亚洲一二三四久久| 亚洲欧美日韩精品久久久| 亚洲第一综合天堂另类专| 亚洲伦理精品| 国产一区二区三区免费不卡| 亚洲国产精品久久久久久女王| 国产精品久久久久久久久久免费看 | 欧美在线精品一区| 欧美大胆人体视频| 久久国产精彩视频| 欧美精品一区三区在线观看| 久久不射网站| 欧美日韩亚洲激情| 欧美大片国产精品| 国产精品综合久久久| 亚洲国产精品久久久久秋霞蜜臀 | 亚洲美女免费视频| 久久av二区| 亚久久调教视频| 欧美精品一区二区三区在线播放 | 久久蜜臀精品av| 欧美肉体xxxx裸体137大胆| 欧美成年人网站| 国产网站欧美日韩免费精品在线观看 | 亚洲欧洲在线视频| 国产三区精品| 亚洲一区二区三区成人在线视频精品 | 欧美日韩一区二区免费在线观看| 久热精品视频在线观看一区| 国产精品久久久久久久久免费樱桃| 蜜桃av噜噜一区| 国产亚洲福利社区一区| 在线中文字幕一区| 亚洲精品在线一区二区| 老妇喷水一区二区三区| 狂野欧美一区| 好看的av在线不卡观看| 欧美一区二区三区另类| 欧美在线综合视频| 国产欧美一区二区视频| 亚洲新中文字幕| 亚洲一区二区三区中文字幕在线| 欧美福利视频| 亚洲日本一区二区| 亚洲麻豆av| 欧美日韩国产精品| 亚洲人妖在线| 99在线观看免费视频精品观看| 免费试看一区| 亚洲高清免费在线| 亚洲激情六月丁香| 欧美国产另类| 日韩一级免费| 亚洲欧美日韩系列| 国产日韩一区二区三区在线| 欧美专区在线观看| 欧美sm视频| 99视频有精品| 国产精品爽爽爽| 欧美一区二区大片| 美女精品一区| 日韩亚洲欧美成人一区| 国产精品久久二区二区| 亚洲欧美精品中文字幕在线| 久久成人18免费观看| 在线高清一区| 欧美日韩激情小视频| 亚洲一级免费视频| 久久这里只有| 一区二区日本视频| 国产日韩欧美综合一区| 久久成人一区二区| 亚洲国产欧洲综合997久久| 一本久久综合| 国产综合自拍| 欧美日韩不卡视频| 亚洲欧美日韩天堂一区二区| 免费成人毛片| 亚洲欧美精品suv| 亚洲第一精品在线| 欧美色综合网| 久久久青草婷婷精品综合日韩 | 亚洲欧美在线看| 在线观看日韩国产| 欧美色中文字幕| 久久久999精品免费| 亚洲理伦电影| 老司机午夜免费精品视频| 日韩一级免费| 伊人精品成人久久综合软件| 欧美日韩视频在线一区二区| 久久精品国产精品亚洲综合| 日韩视频免费观看| 欧美sm极限捆绑bd| 久久久xxx| 亚洲网在线观看| 亚洲精品日韩在线观看| 狠狠久久亚洲欧美专区| 国产精品video| 欧美国产亚洲另类动漫| 久久九九久精品国产免费直播| 一区二区三区精密机械公司| 欧美成人一区二区在线 | 亚洲欧洲综合| 国产一区二区三区在线观看免费视频| 欧美日本一区二区三区| 久久夜色精品国产亚洲aⅴ| 亚洲欧美另类中文字幕| 中文无字幕一区二区三区| 亚洲欧洲日本mm| 欧美国产精品一区| 久久综合九色综合网站| 欧美一级一区| 亚洲女人天堂av| 亚洲一区二区精品在线观看| 亚洲精品在线电影| 亚洲精品一区在线观看| 亚洲电影免费在线| 激情综合电影网| 黑丝一区二区| 一区福利视频| 亚洲高清在线观看| 亚洲黄色一区| 亚洲精选国产| 一区二区欧美精品| 亚洲午夜久久久久久尤物| 中日韩高清电影网| 亚洲性视频网站| 午夜久久影院| 久久久久久一区二区| 久久理论片午夜琪琪电影网| 美女诱惑黄网站一区| 米奇777在线欧美播放| 欧美成年人视频| 91久久久久久久久| 亚洲免费电影在线观看| 99re8这里有精品热视频免费| 日韩午夜激情av| 亚洲一级影院| 久久久久国色av免费观看性色| 久久精品视频亚洲| 欧美肥婆在线| 国产精品国产三级国产普通话99| 国产精品高潮呻吟视频| 国产亚洲人成a一在线v站| 在线免费高清一区二区三区| 亚洲精品黄网在线观看| 亚洲图片欧美午夜| 久久精品成人欧美大片古装| 欧美成人国产| 中文日韩在线| 麻豆久久婷婷| 国产精品久久7| 在线观看一区| 亚洲影院免费观看| 麻豆精品视频| 在线视频精品一区| 久久久久国色av免费看影院 | 久久久一本精品99久久精品66| 欧美成人一区二区三区| 国产精品久久久久一区| 伊人夜夜躁av伊人久久| 亚洲视频视频在线| 毛片av中文字幕一区二区| 亚洲七七久久综合桃花剧情介绍| 亚洲一级片在线观看| 欧美freesex8一10精品| 国产精品久久久久久久久久免费 | 免费成年人欧美视频| 中文网丁香综合网| 久久亚洲美女| 国产精品无码永久免费888| 亚洲国产欧美一区二区三区同亚洲 | 亚洲国产美女| 久久久免费av| 亚洲桃花岛网站| 欧美日韩八区| 最新成人在线| 母乳一区在线观看|