一個程序包含幾個段

站在彙編語言的角度,一個程序分爲:
數據段 -- DS
堆棧段 -- SS
代碼段 -- CS
擴展段 -- ES

站在高級語言的角度,根據APUE,一個程序分爲如下段:
text
data (initialized)
bss
stack
heap

代碼段 -- text
text段在內存中被映射爲只讀,但.data和.bss是可寫的。
text段是程序代碼段,在AT91庫中是表示程序段的大小,它是由編譯器在編譯連接時自動計算的,當你在鏈接定位文件中將該符號放置在代碼段後,那麼該符號表示的值就是代碼段大小,編譯連接時,該符號所代表的值會自動代入到源程序中。

數據段 -- data&bss
data包含靜態初始化的數據,所以有初值的全局變量和static變量在data區。段的起始位置也是由連接定位文件所確定,大小在編譯連接時自動分配,它和你的程序大小沒有關係,但和程序使用到的全局變量,常量數量相關。
bss是英文Block Started by Symbol的簡稱,通常是指用來存放程序中未初始化的全局變量的一塊內存區域,在程序載入時由內核清0。BSS段屬於靜態內存分配。它的初始值也是由用戶自己定義的連接定位文件所確定,用戶應該將它定義在可讀寫的RAM區內,源程序中使用malloc分配的內存就是這一塊,它不是根據data大小確定,主要由程序中同時分配內存最大值所確定,不過如果超出了範圍,也就是分配失敗,可以等空間釋放之後再分配。

stack/heap:
棧(stack)保存函數的局部變量和參數。是一種“後進先出”(Last In First Out,LIFO)的數據結構,這意味着最後放到棧上的數據,將會是第一個從棧上移走的數據。對於哪些暫時存貯的信息,和不需要長時間保存的信息來說,LIFO這種數據結構非常理想。在調用函數或過程後,系統通常會清除棧上保存的局部變量、函數調用信息及其它的信息。棧另外一個重要的特徵是,它的地址空間“向下減少”,即當棧上保存的數據越多,棧的地址就越低。棧(stack)的頂部在可讀寫的RAM區的最後。
堆(heap)保存函數內部動態分配內存,是另外一種用來保存程序信息的數據結構,更準確的說是保存程序的動態變量。堆是“先進先出”(First In first Out,FIFO)數據結構。它只允許在堆的一端插入數據,在另一端移走數據。堆的地址空間“向上增加”,即當堆上保存的數據越多,堆的地址就越高。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章