malloc和new

1.malloc

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

1.calloc

void *calloc( size_t num, size_t size );

函數返回一個指向num 數組空間,每一數組元素的大小爲size。如果錯誤發生返回NULL。

2.malloc

void *malloc( size_t size );

函數指向一個大小爲size的空間,如果錯誤發生返回NULL。

3.realloc

void *realloc( void *ptr, size_t size )

函數將ptr 對象的儲存空間改變爲給定的大小size。 返回值是指向新空間的指針,如果錯誤發生返回NULL。

4.總結:

1.函數使用需包含一個頭文件#include<stdlib.h>

2.malloc函數會返回開闢空間的首地址

3.由malloc動態申請的內存空間是堆式的內存空間。而靜態的內存的空間是棧式的

4.當需要的內存過大,或者不確定內存需求時,則使用動態內存開闢空間

2.new

1.new operator(new表達式)

class A{

    int a;

};

A * array=new A[101];

申請內存和初始化

2.operator new (new操作符)

類似於malloc,只負責申請內存

A* array=(A*) ::operator new(sizeof(A) *101);

3.placement new

用於在給定的內存中初始化對象

class A{
    int a;
    void* operator new(size_t size)
    printf("haha\n");
}

注意:

1、用戶是無法主動調用構造函數的,所以需要藉助placement new,但是用戶可以主動調用析構函數,所以用完這些對象後,調用析構函數,然後用對應分配內存的方法去釋放內存。

2、事實上malloc並不一定比operatornew節省多少時間,用placement new常常是爲了考慮性能,所以會配合內存池一起使用。

4.總結

1.new int;//開闢一個存放整數的存儲空間,返回一個指向該存儲空間的地址(即指針)

2.new int(100);//開闢一個存放整數的空間,並指定該整數的初值爲100,返回一個指向該存儲空間的地址

3.new int[5][4];//開闢一個存放二維整型數組(大小爲5*4)的空間,返回首元素的地址。用new分配數組空間時不能指定初值。

4.delete [] pt;//在指針變量前面加一對方括號,表示是對數組空間的操作

3.malloc/free 和new/delete的區別

1.屬性:

new/delete是C++關鍵字,需要編譯器支持。malloc/free是C語言庫函數,需要頭文件支持c。

2.內存區域:

new操作符從自由存儲區(free store)上爲對象動態分配內存空間,而malloc函數從堆上動態分配內存。(自由存儲區是C++基於new操作符的一個抽象概念,凡是通過new操作符進行內存申請,該內存即爲自由存儲區。而堆是操作系統中的術語,是操作系統所維護的一塊特殊內存,用於程序的內存動態分配,C語言使用malloc從堆上分配內存,使用free釋放已分配的對應內存。自由存儲區不等於堆,如上所述,佈局new就可以不位於堆中。 在C++中,內存區分爲5個區,分別是堆、棧、自由存儲區、全局/靜態存儲區、常量存儲區;在C中,C內存區分爲堆、棧、全局/靜態存儲區、常量存儲區;)

3.參數:

new申請內存分配時無須指定內存塊的大小,編譯器會根據類型信息自行計算。而malloc則需要顯式地指出所需內存的尺寸

3.返回類型:

new操作符內存分配成功時,返回的是對象類型的指針,類型嚴格與對象匹配,無須進行類型轉換,故new是符合類型安全性的操作符,失敗是拋出異常。而malloc內存分配成功則是返回void * ,需要通過強制類型轉換將void*指針轉換成我們需要的類型,失敗時返回NULL。

4.構造和析構: 

new會先調用operator new函數,申請足夠的內存(通常底層使用malloc實現)。然後調用類型的構造函數,初始化成員變量,最後返回自定義類型指針。delete先調用析構函數,然後調用operator delete函數釋放內存(通常底層使用free實現;malloc/free是庫函數,只能動態的申請和釋放內存,無法強制要求其做自定義類型對象構造和析構工作。

5.重載:

C++允許重載new/delete操作符,特別的,佈局new的就不需要爲對象分配內存,而是指定了一個地址作爲內存起始區域,new在這段內存上爲對象調用構造函數完成初始化工作,並返回此地址。而malloc不允許重載。

6.相互調用:

new的實現可以用malloc,malloc的實現不可以使用new;

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