主要理解了Linux進程的棧和函數的棧幀的區別和聯系
上圖中刻畫的是一個Linux進程的結構圖,其中本文想要關注的棧如上圖所示是棧底在0xc0000000地址遞減的一塊進程內存區域
Linux系統中為每個進程分配的實際大小未做深究
Linux進程的棧的整體認知就是這麼多,即
1)棧底在0xc0000000(並不需要棧底指針,函數的棧幀才需要棧底指針)
2)棧的增長方向,地址遞減方向
3)棧頂指針esp
4)大小未知(不是本文關注的重點)
5)裡面存放的內容是什麼呢?
另一個概念是上文中提到的函數的棧幀的概念及其與Linux進程棧的關系
函數的棧幀就在進程中的棧的結構和分配的地址空間及實際內存中
函數的棧幀整體的理解是:
1)ebp是函數棧幀的棧底
2)esp是棧頂
3)一個進程的所有的函數的棧幀在調用此函數的時候建立,返回調用者後,被調函數的棧幀不再存在
4)所有的函數的棧幀的建立和消失是隨著進程的執行而變化的一個動態過程
進程中的函數在進程提供的棧中要解決的是調用者和被調者的關系
1)如何從調用者進入被調者?
2)如何從被調者返回調用者?
3)調用者如何支配被調者(被調函數參數傳遞)?
4)被調者的價值如何體現(返回值的傳遞)?
等