malloc()與 alloc()區別(藉助資料)
阿新 • • 發佈:2019-02-04
malloc()與 alloc()
C語言跟記憶體分配方式 (1) 從靜態儲存區域分配。記憶體在程式編譯的時候就已經分配好,這塊記憶體在程式的整個執行期間都存在。例如全域性變數,static變數。 (2) 在棧上建立。在執行函式時,函式內區域性變數的儲存單元都可以在棧上建立,函式執行結束時這些儲存單元自動被釋放。棧記憶體分配運算內置於處理器的指令集中,效率很高,但是分配的記憶體容量有限。 (3)從堆上分配,亦稱動態記憶體分配。程式在執行的時候用malloc或new申請任意多少的記憶體,程式設計師自己負責在何時用free或delete釋放記憶體。動態記憶體的生存期由我們決定,使用非常靈活,但問題也最多malloc() 函式和calloc ()函式的主要區別是前者不能初始化所分配的記憶體空間,而後者能。如果由malloc()函式分配的記憶體空間原來沒有被使用過,則其中的每一位可能都是 0;反之,如果這部分記憶體空間曾經被分配、釋放和重新分配,則其中可能遺留各種各樣的資料。也就是說,使用malloc()函式的程式開始時(記憶體空間還 沒有被重新分配)能正常執行,但經過一段時間後(記憶體空間已被重新分配)可能會出現問題。
calloc() 函式會將所分配的記憶體空間中的每一位都初始化為零,也就是說,如果你是為字元型別或整數型別的元素分配記憶體,那麼這些元素將保證會被初始化為零;如果你是為指標型別的元素分配記憶體,那麼這些元素通常(但無法保證)會被初始化為空指標;如果你是為實數型別的元素分配記憶體,那麼這些元素可能(只在某些計算機中)會被初始化為浮點型的零。 malloc() 函式和calloc ()函式的另一點區別是calloc()函式會返回一個由某種物件組成的陣列,但malloc()函式只返回一個物件。為了明確是為一個數組分配記憶體空 間,有些程式設計師會選用calloc()函式。但是,除了是否初始化所分配的記憶體空間這一點之外,絕大多數程式設計師認 為以下兩種函式呼叫方式沒有區別: calloc(numElements ,sizeOfElement); malloc(numElements *sizeOfElement) ; 需要解釋的一點是,理論上(按 照ANSIC標準)指標的算術運算只能在一個指定的陣列中進行,但是在實踐中,即使C編譯程式或翻譯器遵循這種規定,許多C程式還是衝破了這種限制。因 此,儘管malloc()函式並不能返回一個數組,它所分配的記憶體空間仍然能供一個數組使用(對realloc()函式來說同樣如此,儘管它也不能返回一 個數組)。 總之,當你在calloc()函式和malloc()函式之間作選擇時,你只需考慮是否要初始化所分配的記憶體空間,而不用考慮函式是否能返回一個數組。 當程式執行過程中malloc了,但是沒有free的話,會造成記憶體洩漏.一部分的記憶體沒有被使用,但是由於沒有free,因此係統認為這部分記憶體還在使用,造成不斷的向系統申請記憶體,是的系統可用記憶體不斷減少.但是,記憶體洩漏僅僅指程式在執行時,程式退出時,OS將回收所有的資源.因此,適當的重起一下程式,有時候還是有點作用.