C程序在內存中的組織方式
對我本人來說,學習任何一種高級語言,總想知道高級語言是如何被編譯并載入內存的,一個程序的運行,在計算機內存中是怎樣組織的等等問題,總想打破砂鍋問到底,有好多疑問,因此我就學習了匯編語言,匯編語言確實讓你能了解很多底層的東西,它可以直接跟寄存器接觸,內存單元接觸,自己創建一個棧空間,也可以自己編寫安裝自己需要的中斷例程,讓中斷向量表相應的入口地址指向自己編寫安裝的中斷例程,讓你了解什么是端口,怎樣通過匯編指令對這些端口進行讀寫,讓你了解鍵盤即鼠標的工作原理,自己編寫鍵盤程序等等,確實很有意思,但是匯編有優點,缺點也不少,這里不多說,畢竟主要講的是C語言。
學習任何東西,都不能了解就好,不能一知半解,畢竟大二全不如小而精,人才都是精通某一領域,在某一領域上作出貢獻,更不能沒信心,一有難題解決不了,就失去信心,從而放棄,那是絕不可取的,如果這樣那么一輩子也做不了什么事。算了,侃這么多跟標題無關的事,請大家原諒,下面正式介紹一下C語言在內存中的組織方式,其實沒有過多要講,但是還是介紹一下吧!
一個可以執行的C程序,一般說來有四個區域組成,哪四個呢?你猜?當然不可能要你猜,猜是猜不著的,那就說出來吧:①、代碼段,程序運行時執行的機器指令,何為機器指令,也就是一連串的二進制數,電腦認不得高級語言,必須被編譯等階段轉換成二進制機器指令才能被機器所知曉,如if(a>b)…,它也會被編譯成機器指令(二進制代碼),具體是什么樣的機器指令,說實話我也不太清楚。②、靜態數據區,包含程序運行周期中一直存在的數據,比如全局變量和靜態變量,什么字符串常量啊,等等。③、堆區:程序運行時動態分配的存儲空間,一般由程序員分配和釋放,比如用malloc、calloc等。堆的分配方式類似于鏈表(以后會說到),但是它跟數據結構中的堆不是一回事,完了,差點又跑偏了,不說了。④、當然就是堆棧中的棧了,一般由系統自動分配,其包含函數的調用信息,存放函數的參數值,還有就是局部變量的值,操作方式跟數據結構中的棧很類似。
舉個類子:
int a; ①
char b; ②
int main(){
int b=10; ③
static int n=2; ④
char c[]={'a','b'}; ⑤
char *p="i love you"; ⑥
int *p=(int *)malloc(sizeof(int)); ⑦
}
上面一段程序①跟②,因為是全局變量,很容易想到它們在靜態數據區。③處的數據因為是局部的,所以在棧區,④嘛,因為有static修飾符修飾,靜態局部變量故在靜態數據區,⑤不要說,也是在棧區,局部字符數組,也是局部變量。⑥有所區別,指針變量p毋庸置疑在棧區,但是后面的i love you是常量字符串,卻在靜態數據區。指針變量p指向字符串常量。⑦不多說,在堆區。
以上就是關于C程序在內存中組織方式的簡要介紹。