編譯時分配內(nèi)存嗎?
編譯時分配內(nèi)存嗎?
編譯時分配內(nèi)存嗎?編譯時是不分配內(nèi)存的。下面是學(xué)習(xí)啦小編為大家收集整理的一些相關(guān)知識,希望對大家有幫助!
編譯時分配內(nèi)存嗎?
編譯時與運行時的內(nèi)存情況
1.編譯時不分配內(nèi)存
編譯時是不分配內(nèi)存的。此時只是根據(jù)聲明時的類型進(jìn)行占位,到以后程序執(zhí)行時分配內(nèi)存才會正確。所以聲明是給編譯器看的,聰明的編譯器能根據(jù)聲明幫你識別錯誤。
2.運行時必分配內(nèi)存
運行時程序是必須調(diào)到“內(nèi)存”的。因為CPU(其中有多個寄存器)只與內(nèi)存打交道的。程序在進(jìn)入實際內(nèi)存之前要首先分配物理內(nèi)存。
3.編譯過程
只能簡單說一下,因為如果要詳細(xì)的話,就是一本書了《編譯原理》。編譯器能夠識別語法,數(shù)據(jù)類型等等。然后逐行逐句檢查編譯成二進(jìn)制數(shù)據(jù)的obj文件,然后再由鏈接程序?qū)⑵滏溄映梢粋€EXE文件。此時的程序是以EXE文件的形式存放在磁盤上。
4.運行過程
當(dāng)執(zhí)行這個EXE文件以后,此程序就被加載到內(nèi)存中,成為進(jìn)程。此時一開始程序會初始化一些全局對象,然后找到入口函數(shù)(main()或者WinMain()),就開始按程序的執(zhí)行語句開始執(zhí)行。此時需要的內(nèi)存只能在程序的堆上進(jìn)行動態(tài)增加/釋放了。
編譯時分配內(nèi)存嗎?另一種解釋
1、所謂在編譯期間分配空間指的是靜態(tài)分配空間(相對于用new動態(tài)申請空間),如全局變量或靜態(tài)變量(包括一些復(fù)雜類型的常量),它們所需要的空間大小可以 明確計算出來,并且不會再改變,因此它們可以直接存放在可執(zhí)行文件的特定的節(jié)里(而且包含初始化的值),程序運行時也是直接將這個節(jié)加載到特定的段中,不 必在程序運行期間用額外的代碼來產(chǎn)生這些變量。
其實在運行期間再看“變量”這個概念就不再具備編譯期間那么多的屬性了(諸如名稱,類型,作用域,生存期等等),對應(yīng)的只是一塊內(nèi)存(只有首址和大小), 所以在運行期間動態(tài)申請的空間,是需要額外的代碼維護(hù),以確保不同變量不會混用內(nèi)存。比如寫new表示有一塊內(nèi)存已經(jīng)被占用了,其它變量就不能再用它了; 寫delete表示這塊內(nèi)存自由了,可以被其它變量使用了。(通常我們都是通過變量來使用內(nèi)存的,就編碼而言變量是給內(nèi)存塊起了個名字,用以區(qū)分彼此)
內(nèi)存申請和釋放時機(jī)很重要,過早會丟失數(shù)據(jù),過遲會耗費內(nèi)存。特定情況下編譯器可以幫我們完成這項復(fù)雜的工作(增加額外的代碼維護(hù)內(nèi)存空間,實現(xiàn)申請和釋 放)。從這個意義上講,局部自動變量也是由編譯器負(fù)責(zé)分配空間的。進(jìn)一步講,內(nèi)存管理用到了我們常常掛在嘴邊的堆和棧這兩種數(shù)據(jù)結(jié)構(gòu)。
最后對于“編譯器分配空間”這種不嚴(yán)謹(jǐn)?shù)恼f法,你可以理解成編譯期間它為你規(guī)劃好了這些變量的內(nèi)存使用方案,這個方案寫到可執(zhí)行文件里面了(該文件中包含若干并非出自你大腦衍生的代碼),直到程序運行時才真正拿出來執(zhí)行。
2、編譯其實只是一個掃描過程,進(jìn)行詞法語法檢查,代碼優(yōu)化而已,編譯程序越好,程序運行的時候越高效。 我想你說的“編譯時分配內(nèi)存”是指“編譯時賦初值”,它只是形成一個文本,檢查無錯誤,并沒有分配內(nèi)存空間。
當(dāng)你運行時,系統(tǒng)才把程序?qū)雰?nèi)存。一個進(jìn)程(即運行中的程序)在主要包括以下五個分區(qū): 棧、堆、bss、data、code
代碼(編譯后的二進(jìn)制代碼)放在code區(qū),代碼中生成的各種變量、常量按不同類型分別存放在其它四個區(qū)。系統(tǒng)依照代碼順序執(zhí)行,然后依照代碼方案改變或調(diào)用數(shù)據(jù),這就是一個程序的運行過程。
3、
編譯時分配內(nèi)存 --------------- 編譯時是不分配內(nèi)存的。此時只是根據(jù)聲明時的類型進(jìn)行占位,到以后程序執(zhí)行時分配內(nèi)存才會正確。所以聲明是給編譯器看的,聰明的編譯器能根據(jù)聲明幫你識別錯誤。
運行時分配內(nèi)存 --------------- 這是對的,運行時程序是必須調(diào)到“內(nèi)存”的。因為CPU(其中有多個寄存器)只與內(nèi)存打交道的。程序在進(jìn)入實際內(nèi)存之前要首先分配物理內(nèi)存。
編譯過程 -------------- 只能簡單說一下,因為如果要詳細(xì)的話,就是一本書了《編譯原理》。編譯器能夠識別語法,數(shù)據(jù)類型等等。然后逐行逐句檢查編譯成二進(jìn)制數(shù)據(jù)的obj文件,然后再由鏈接程序?qū)⑵滏溄映梢粋€EXE文件。此時的程序是以EXE文件的形式存放在磁盤上。
運行過程 -------------- 當(dāng)執(zhí)行這個EXE文件以后,此程序就被加載到內(nèi)存中,成為進(jìn)程。此時一開始程序會初始化一些全局對象,然后找到入口函數(shù)(main()或者WinMain()),就開始按程序的執(zhí)行語句開始執(zhí)行。此時需要的內(nèi)存只能在程序的堆上進(jìn)行動態(tài)增加/釋放了。