首頁 > 軟體

Linux進程的棧和進程中函數的棧幀

2020-06-16 18:05:16

主要理解了Linux進程的棧和函數的棧幀的區別和聯絡

上圖中刻畫的是一個Linux進程的結構圖,其中本文想要關注的棧如上圖所示是棧底在0xc0000000地址遞減的一塊進程記憶體區域
Linux系統中為每個進程分配的實際大小未做深究
Linux進程的棧的整體認知就是這麼多,即
1)棧底在0xc0000000(並不需要棧底指標,函數的棧幀才需要棧底指標)
2)棧的增長方向,地址遞減方向
3)棧頂指標esp
4)大小未知(不是本文關注的重點)
5)裡面存放的內容是什麼呢?


另一個概念是上文中提到的函數的棧幀的概念及其與Linux進程棧的關係
函數的棧幀就在進程中的棧的結構和分配的地址空間及實際記憶體中
函數的棧幀整體的理解是:
1)ebp是函數棧幀的棧底
2)esp是棧頂
3)一個進程的所有的函數的棧幀在呼叫此函數的時候建立,返回撥用者後,被調函數的棧幀不再存在
4)所有的函數的棧幀的建立和消失是隨著進程的執行而變化的一個動態過程


進程中的函數在進程提供的棧中要解決的是呼叫者和被調者的關係
1)如何從呼叫者進入被調者?
2)如何從被調者返回撥用者?
3)呼叫者如何支配被調者(被調函數引數傳遞)?
4)被調者的價值如何體現(返回值的傳遞)?


IT145.com E-mail:sddin#qq.com