一個(gè)函數(shù)的調(diào)用過(guò)程

1、參數(shù)拷貝(參數(shù)實(shí)例化)。
2、保存當(dāng)前指令的下一條指令,并跳轉(zhuǎn)到被調(diào)函數(shù)。
這些操作均在main函數(shù)中進(jìn)行。

1、移動(dòng)ebp、esp形成新的棧幀結(jié)構(gòu)。
2、壓棧(push)形成臨時(shí)變量并執(zhí)行相關(guān)操作。
3、return一個(gè)值。
這些操作在函數(shù)中進(jìn)行。

被調(diào)函數(shù)完成相關(guān)操作后需返回到原函數(shù)中執(zhí)行下一條指令,
1、出棧(pop)。
2、回復(fù)main函數(shù)的棧幀結(jié)構(gòu)。(pop )
3、返回main函數(shù)
這些操作也在函數(shù)中進(jìn)行。

整個(gè)過(guò)程就三步:
1、根據(jù)調(diào)用的函數(shù)名找到函數(shù)入口;
2、在棧中申請(qǐng)調(diào)用函數(shù)中的參數(shù)函數(shù)體內(nèi)定義的變量的內(nèi)存空間
3、函數(shù)執(zhí)行完后,釋放函數(shù)在棧中的申請(qǐng)的參數(shù)和變量的空間,最后返回值(如果有的話)
函數(shù)調(diào)用過(guò)程和中斷處理過(guò)程一模一樣

總結(jié):每一個(gè)函數(shù)調(diào)用都會(huì)分配函數(shù)棧,在棧內(nèi)進(jìn)行函數(shù)執(zhí)行過(guò)程。調(diào)用前,先把返回地址壓棧,然后把當(dāng)前函數(shù)的esp指針壓棧。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容