1. 程式人生 > >new/delete 和malloc/free 的區別

new/delete 和malloc/free 的區別

一、基本概念

     malloc/free:

1、函式原型及說明:

      void *malloc(long NumBytes):該函式分配了NumBytes個位元組,並返回了指向這塊記憶體的指標。如果分配失敗,則返回一個空指標(NULL)

      void free(void *FirstByte): 該函式是將之前用malloc分配的空間還給程式或者是作業系統,也就是釋放了這塊記憶體,讓它重新得到自由。

2.記憶體操作:

     malloc函式的引數是接受需要分配的記憶體位元組數,如果記憶體能夠滿足請求量,那麼將會返回:指向被分配的記憶體塊起始位置

     free函式釋放的是指標指向的記憶體(不是釋放的指標本身,不會刪除指標本身),其中指標必須指向所釋放記憶體空間的首地址

new/delete:

1.操作時發生事件:

     new的時候會有兩個事件發生:1).記憶體被分配(通過operator new 函式)  2).為被分配的記憶體呼叫一個或多個建構函式構建物件

     delete的時候,也有兩件事發生:1).為將被釋放的記憶體呼叫一個或多個解構函式  2).釋放記憶體(通過operator delete 函式)

2.特殊應用:

   使用delete是未加括號,delete便假設刪除物件是單一物件。否則便假設刪除物件是個陣列

   因此,如果在呼叫new時使用了[],則在呼叫delete時也使用[],如果你在呼叫new的時候沒有[],那麼也不應該在呼叫時使用[]。

二、malloc/free 和new/delete 的本質區別:

1.malloc/free是C/C++語言的標準庫函式,new/delete是C++的運算子

2.new能夠自動分配空間大小

3.對於使用者自定義的物件而言,用maloc/free無法滿足動態管理物件的要求。物件在建立的同時要自動執行建構函式,物件在消亡之前要自動執行解構函式。由於malloc/free是庫函式而不是運算子,不在編譯器控制權限之內,不能夠把執行建構函式和解構函式的任務強加於malloc/free。因此C++需要一個能對物件完成動態記憶體分配和初始化工作的運算子new,以及一個能對物件完成清理與釋放記憶體工作的運算子delete---簡而言之 new/delete能進行對物件進行構造和解構函式的呼叫進而對記憶體進行更加詳細的工作,而malloc/free不能。

三、聯絡

既然new/delete的功能完全覆蓋了malloc/free,為什麼C++還保留malloc/free呢?因為C++程式經常要呼叫C函式,而C程式只能用malloc/free管理動態記憶體。如果用free釋放“new建立的動態物件”,那麼該物件因無法執行解構函式而可能導致程式出錯。如果用delete釋放“malloc申請的動態記憶體”,理論上講程式不會出錯,但是該程式的可讀性很差。所以new/delete,malloc/free必須配對使用。

四、使用範例

void * malloc(size_t size);

用malloc 申請一塊長度為length 的整數型別的記憶體,程式如下:

int *p = (int *) malloc(sizeof(int) * length); 

我們應當把注意力集中在兩個要素上:“型別轉換”和“sizeof”。

1. malloc 返回值的型別是void *,所以在呼叫malloc 時要顯式地進行型別轉換,將void * 轉換成所需要的指標型別。