溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C++函數(shù)棧幀的示例分析

發(fā)布時間:2021-07-09 11:04:01 來源:億速云 閱讀:150 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細講解有關(guān)C++函數(shù)棧幀的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

    一、什么是函數(shù)棧幀

    每一次函數(shù)調(diào)用都是一個過程,為函數(shù)開辟棧空間,用于本次函數(shù)調(diào)用中臨時變量的保存、現(xiàn)場保護。這塊??臻g我們稱為函數(shù)棧幀。棧是從高地址向低地址延伸的。寄存器ebp指向當前的棧幀的底部(高地址),寄存器esp指向當前的棧幀的頂部(低地址)

    注:esp:棧指針寄存器(extended stack pointer),其內(nèi)存放著一個指針,該指針永遠指向系統(tǒng)棧最上面一個棧幀的棧頂。
    bsp:基址指針寄存器(extended base pointer),其內(nèi)存放著一個指針,該指針永遠指向系統(tǒng)棧最上面一個棧幀的底部。

    入棧push和出棧pop

    push ebp就等于將ebp的值保存到棧中,并且將當前esp下移

    pop ebp就等于將ebp的值從棧中取出來,將ebp指向這個值

    內(nèi)存空間大致可以用下圖表示:

    C++函數(shù)棧幀的示例分析

    二、具體原理

    我們來通過運行程序來分析,有如下程序

     int sum(int _a, int _b)
     {
    	 int res = 0;
    	 res = _a + _b;
     
    	 return res;
     }
     
     
     int main()
     {
    	 int a = 10;
    	 int b = 20;
     
    	 int ret = sum(a, b);
    	 printf("ret=%d\n", ret);
             return 0;
    }

    使用vs2017調(diào)試,查看反匯編

    2.1 main函數(shù)的調(diào)用

    main在調(diào)用之前如圖:

    C++函數(shù)棧幀的示例分析

    C++函數(shù)棧幀的示例分析

    2.2 sum函數(shù)的調(diào)用

    sum函數(shù)在調(diào)用之前

    C++函數(shù)棧幀的示例分析

    C++函數(shù)棧幀的示例分析

    sum函數(shù)內(nèi)的內(nèi)存分布

    C++函數(shù)棧幀的示例分析

    在上述的匯編碼中我們可以看到在函數(shù)開始的時候,習(xí)慣上以這么l兩段代碼開始

    push ebp  
     
    mov ebp,esp

    按照字面上理解,上面兩句話的意思是將ebp推入棧中,之后讓ebp等于esp

    在函數(shù)調(diào)用之前,將調(diào)用者的函數(shù)(caller)的ebp存入棧,以便于在執(zhí)行完畢后恢復(fù)現(xiàn)場;

    下一步,sum函數(shù)必須為它的局部變量分配空間,同時,也必須為它可能用到的一些臨時變量分配空間;

     sub esp, 0cch; // 減去的值根據(jù)程序而定;

    之后會根據(jù)情況看是否保存某些特定的寄存器(EBX,ESI和EDI);

    而ebp的值會保持固定,局部變量和臨時存儲則都可以通過基準指針ebp加偏移量找到;

    C++函數(shù)棧幀的示例分析

    在函數(shù)執(zhí)行完畢,控制流返回到調(diào)用者的函數(shù)(caller)之前會進行下述操作

    C++函數(shù)棧幀的示例分析

    所謂有始有終,這是會還原上面保存的寄存器值,之后還原esp的值(上一個函數(shù)調(diào)用之前的esp被保存在固定的ebp中)與ebp值。這一過程被稱為還原現(xiàn)場之后通過ret返回上一個函數(shù)。

    C++函數(shù)棧幀的示例分析

    關(guān)于“C++函數(shù)棧幀的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

    向AI問一下細節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

    c++
    AI