Linux進程的棧和進程中函數的棧幀及其結構
來源:程序員人生 發布時間:2015-03-18 09:29:14 閱讀次數:4373次
主要理解了Linux進程的棧和函數的棧幀的區分和聯系

上圖中刻畫的是1個Linux進程的結構圖,其中本文想要關注的棧如上圖所示是棧底在0xc0000000地址遞減的1塊進程內存區域
Linux系統中為每一個進程分配的實際大小未做深究
Linux進程的棧的整體認知就是這么多,即
1)棧底在0xc0000000(其實不需要棧底指針,函數的棧幀才需要棧底指針)
2)棧的增長方向,地址遞減方向
3)棧頂指針esp
4)大小未知(不是本文關注的重點)
5)里面寄存的內容是甚么呢?
進程的棧中寄存的是函數調用的棧幀
即另外一個概念是上文中提到的函數的棧幀的概念及其與Linux進程棧的關系
函數的棧幀就在進程中的棧的結構和分配的地址空間及實際內存中
函數的棧幀整體的理解是:
1)ebp是函數棧幀的棧底
2)esp是棧頂(1個函數的活動記錄就在ebp(高地址)和esp(低地址)之間)
3)1個進程的所有的函數的棧幀在調用此函數的時候建立,返回調用者后,被調函數的棧幀不再存在
4)所有的函數的棧幀的建立和消失是隨著進程的履行而變化的1個動態進程
5)棧幀中寄存的內容是甚么呢?
棧幀中寄存的內容1般包括以下幾個方面的內容:
1)函數的返回地址和參數
2)臨時變量:包括函數的非靜態局部變量和編譯器自動生成的其他變量
3)保存的上下文:包括在函數調用前后需要保證不變的寄存器值
進程中的函數在進程提供的棧中要解決的是調用者和被調者的關系
1)如何從調用者進入被調者?call
2)如何從被調者返回調用者?ret
3)調用者如何安排被調者(被調函數參數傳遞)?參數
4)被調者的價值如何體現(返回值的傳遞)?寄存器eax、edx
其中還有兩個問題值得去看
1)被調函數返回值的傳遞方式
2)函數的調用慣例
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈