new/delete与malloc/free的区别和联系
2、new 不止是分配內(nèi)存,而且會(huì)調(diào)用類的構(gòu)造函數(shù),同理delete會(huì)調(diào)用類的析構(gòu)函數(shù),而malloc則只分配內(nèi)存,不會(huì)進(jìn)行初始化類成員的工作,同樣free也不會(huì)調(diào)用析構(gòu)函數(shù)
3、內(nèi)存泄漏對(duì)于malloc或者new都可以檢查出來的,區(qū)別在于new可以指明是那個(gè)文件的那一行,而malloc沒有這些信息。
4、new 和 malloc效率比較
new 有三個(gè)字母, malloc有六個(gè)字母
new可以認(rèn)為是malloc加構(gòu)造函數(shù)的執(zhí)行。
new出來的指針是直接帶類型信息的。
而malloc返回的都是void指針。
一:new delete 是運(yùn)算符,malloc,free是函數(shù)
malloc與free是C++/C語言的標(biāo)準(zhǔn)庫函數(shù),new/delete是C++的運(yùn)算符。它們都可用于申請(qǐng)動(dòng)態(tài)內(nèi)存和釋放內(nèi)存。
對(duì)于非內(nèi)部數(shù)據(jù)類型的對(duì)象而言,光用maloc/free無法滿足動(dòng)態(tài)對(duì)象的要求。對(duì)象在創(chuàng)建的同時(shí)要自動(dòng)執(zhí)行構(gòu)造函數(shù),對(duì)象在消亡之前要自動(dòng)執(zhí)行 析構(gòu)函數(shù)。由于malloc/free是庫函數(shù)而不是運(yùn)算符,不在編譯器控制權(quán)限之內(nèi),不能夠把執(zhí)行構(gòu)造函數(shù)和析構(gòu)函數(shù)的任務(wù)強(qiáng)加于malloc /free。
因此C++語言需要一個(gè)能完成動(dòng)態(tài)內(nèi)存分配和初始化工作的運(yùn)算符new,以及一個(gè)能完成清理與釋放內(nèi)存工作的運(yùn)算符delete。注意new/delete不是庫函數(shù)。
我們先看一看malloc/free和new/delete如何實(shí)現(xiàn)對(duì)象的動(dòng)態(tài)內(nèi)存管理,見示例。
class Obj
{
public :
????????? Obj(void){ cout << “Initialization” << endl; }
~Obj(void){ cout << “Destroy” << endl; }
void????? Initialize(void){ cout << “Initialization” << endl; }
void????? Destroy(void){ cout << “Destroy” << endl; }
};
void UseMallocFree(void)
{
????? Obj??? *a = (obj *)malloc(sizeof(obj));???? // 申請(qǐng)動(dòng)態(tài)內(nèi)存
????? a->Initialize();????????????????????????? // 初始化
????? //…
????? a->Destroy();???? // 清除工作
????? free(a);????????? // 釋放內(nèi)存
}
void UseNewDelete(void)
{
????? Obj??? *a = new Obj;??? // 申請(qǐng)動(dòng)態(tài)內(nèi)存并且初始化
????? //…
????? delete a;???????????? // 清除并且釋放內(nèi)存
}
示例用malloc/free和new/delete如何實(shí)現(xiàn)對(duì)象的動(dòng)態(tài)內(nèi)存管理
類Obj的函數(shù)Initialize模擬了構(gòu)造函數(shù)的功能,函數(shù)Destroy模擬了析構(gòu)函數(shù)的功能。函數(shù)UseMallocFree中,由于 malloc/free不能執(zhí)行構(gòu)造函數(shù)與析構(gòu)函數(shù),必須調(diào)用成員函數(shù)Initialize和Destroy來完成初始化與清除工作。函數(shù) UseNewDelete則簡(jiǎn)單得多。
所以我們不要企圖用malloc/free來完成動(dòng)態(tài)對(duì)象的內(nèi)存管理,應(yīng)該用new/delete。由于內(nèi)部數(shù)據(jù)類型的“對(duì)象”沒有構(gòu)造與析構(gòu)的過程,對(duì)它們而言malloc/free和new/delete是等價(jià)的。
既然new/delete的功能完全覆蓋了malloc/free,為什么C++不把malloc/free淘汰出局呢?這是因?yàn)镃++程序經(jīng)常要調(diào)用C函數(shù),而C程序只能用malloc/free管理動(dòng)態(tài)內(nèi)存。
如果用free釋放“new創(chuàng)建的動(dòng)態(tài)對(duì)象”,那么該對(duì)象因無法執(zhí)行析構(gòu)函數(shù)而可能導(dǎo)致程序出錯(cuò)。如果用delete釋放“malloc申請(qǐng)的動(dòng)態(tài) 內(nèi)存”,理論上講程序不會(huì)出錯(cuò),但是該程序的可讀性很差。所以new/delete必須配對(duì)使用,malloc/free也一樣。
二:new delete在實(shí)現(xiàn)上其實(shí)調(diào)用了malloc,free函數(shù)。
三:new operator除了分配內(nèi)存,還要調(diào)用構(gòu)造函數(shù)。
malloc函數(shù)只是負(fù)責(zé)分配內(nèi)存。
本文來自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/hejianhua/archive/2009/10/21/4708037.aspx
類似看法1:
相同點(diǎn):都可用于申請(qǐng)動(dòng)態(tài)內(nèi)存和釋放內(nèi)存
不同點(diǎn):
(1)操作對(duì)象有所不同。
malloc與free是C++/C 語言的標(biāo)準(zhǔn)庫函數(shù),new/delete 是C++的運(yùn)算符。對(duì)于非內(nèi)部數(shù)據(jù)類的對(duì)象而言,光用maloc/free 無法滿足動(dòng)態(tài)對(duì)象的要求。對(duì)象在創(chuàng)建的同時(shí)要自動(dòng)執(zhí)行構(gòu)造函數(shù), 對(duì)象消亡之前要自動(dòng)執(zhí)行析構(gòu)函數(shù)。由于malloc/free 是庫函數(shù)而不是運(yùn)算符,不在編譯器控制權(quán)限之內(nèi),不能夠把執(zhí)行構(gòu)造函數(shù)和析構(gòu)函數(shù)的任務(wù)強(qiáng)加malloc/free。
(2)在用法上也有所不同。
函數(shù)malloc 的原型如下:
void * malloc(size_t size);
用malloc 申請(qǐng)一塊長(zhǎng)度為length 的整數(shù)類型的內(nèi)存,程序如下:
int *p = (int *) malloc(sizeof(int) * length);
我們應(yīng)當(dāng)把注意力集中在兩個(gè)要素上:“類型轉(zhuǎn)換”和“sizeof”。
? malloc 返回值的類型是void *,所以在調(diào)用malloc 時(shí)要顯式地進(jìn)行類型轉(zhuǎn)換,將void * 轉(zhuǎn)換成所需要的指針類型。
? malloc 函數(shù)本身并不識(shí)別要申請(qǐng)的內(nèi)存是什么類型,它只關(guān)心內(nèi)存的總字節(jié)數(shù)。
函數(shù)free 的原型如下:
void free( void * memblock );
為什么free 函數(shù)不象malloc 函數(shù)那樣復(fù)雜呢?這是因?yàn)橹羔榩 的類型以及它所指的內(nèi)存的容量事先都是知道的,語句free(p)能正確地釋放內(nèi)存。如果p 是NULL 指針,那么free
對(duì)p 無論操作多少次都不會(huì)出問題。如果p 不是NULL 指針,那么free 對(duì)p連續(xù)操作兩次就會(huì)導(dǎo)致程序運(yùn)行錯(cuò)誤。
new/delete 的使用要點(diǎn)
運(yùn)算符new 使用起來要比函數(shù)malloc 簡(jiǎn)單得多,例如:
int *p1 = (int *)malloc(sizeof(int) * length);
int *p2 = new int[length];
這是因?yàn)閚ew 內(nèi)置了sizeof、類型轉(zhuǎn)換和類型安全檢查功能。對(duì)于非內(nèi)部數(shù)據(jù)類型的對(duì)象而言,new 在創(chuàng)建動(dòng)態(tài)對(duì)象的同時(shí)完成了初始化工作。如果對(duì)象有多個(gè)構(gòu)造函數(shù),那么new 的語句也可以有多種形式。
如果用new 創(chuàng)建對(duì)象數(shù)組,那么只能使用對(duì)象的無參數(shù)構(gòu)造函數(shù)。例如
Obj *objects = new Obj[100]; // 創(chuàng)建100 個(gè)動(dòng)態(tài)對(duì)象
不能寫成
Obj *objects = new Obj[100](1);// 創(chuàng)建100 個(gè)動(dòng)態(tài)對(duì)象的同時(shí)賦初值1
在用delete 釋放對(duì)象數(shù)組時(shí),留意不要丟了符號(hào)‘[]’。例如
delete []objects; // 正確的用法
delete objects; // 錯(cuò)誤的用法
后者相當(dāng)于delete objects[0],漏掉了另外99 個(gè)對(duì)象。
1 new自動(dòng)計(jì)算需要分配的空間,而malloc需要手工計(jì)算字節(jié)數(shù)
2 new是類型安全的,而malloc不是,比如:
int* p = new float[2]; // 編譯時(shí)指出錯(cuò)誤
int* p = malloc(2*sizeof(float)); // 編譯時(shí)無法指出錯(cuò)誤
new operator 由兩步構(gòu)成,分別是 operator new 和 construct
3 operator new對(duì)應(yīng)于malloc,但operator new可以重載,可以自定義內(nèi)存分配策略,甚至不做內(nèi)存分配,甚至分配到非內(nèi)存設(shè)備上。而malloc無能為力
4 new將調(diào)用constructor,而malloc不能;delete將調(diào)用destructor,而free不能。
5 malloc/free要庫文件支持,new/delete則不要。
1. 本質(zhì)區(qū)別
malloc/free是C/C++語言的標(biāo)準(zhǔn)庫函數(shù),new/delete是C++的運(yùn)算符。
對(duì)于用戶自定義的對(duì)象而言,用maloc/free無法滿足動(dòng)態(tài)管理對(duì)象的要求。對(duì)象在創(chuàng)建的同時(shí)要自動(dòng)執(zhí)行構(gòu)造函數(shù),對(duì)象在消亡之前要自動(dòng)執(zhí)行析構(gòu)函 數(shù)。由于malloc/free是庫函數(shù)而不是運(yùn)算符,不在編譯器控制權(quán)限之內(nèi),不能夠把執(zhí)行構(gòu)造函數(shù)和析構(gòu)函數(shù)的任務(wù)強(qiáng)加于malloc/free。因 此C++需要一個(gè)能完成動(dòng)態(tài)內(nèi)存分配和初始化工作的運(yùn)算符new,以及一個(gè)能完成清理與釋放內(nèi)存工作的運(yùn)算符delete
類 Obj的函數(shù)Initialize實(shí)現(xiàn)了構(gòu)造函數(shù)的功能,函數(shù)Destroy實(shí)現(xiàn)了析構(gòu)函數(shù)的功能。函數(shù)UseMallocFree中,由于 malloc/free不能執(zhí)行構(gòu)造函數(shù)與析構(gòu)函數(shù),必須調(diào)用成員函數(shù)Initialize和Destroy來完成“構(gòu)造”與“析構(gòu)”。所以我們不要用 malloc/free來完成動(dòng)態(tài)對(duì)象的內(nèi)存管理,應(yīng)該用new/delete。由于內(nèi)部數(shù)據(jù)類型的“對(duì)象”沒有構(gòu)造與析構(gòu)的過程,對(duì)它們而言 malloc/free和new/delete是等價(jià)的。
2. 聯(lián)系
既然new/delete的功能完全覆蓋了malloc/free,為什么C++還保留malloc/free呢?因?yàn)镃++程序經(jīng)常要調(diào)用C函數(shù),而C 程序只能用malloc/free管理動(dòng)態(tài)內(nèi)存。如果用free釋放“new創(chuàng)建的動(dòng)態(tài)對(duì)象”,那么該對(duì)象因無法執(zhí)行析構(gòu)函數(shù)而可能導(dǎo)致程序出錯(cuò)。如果用 delete釋放“malloc申請(qǐng)的動(dòng)態(tài)內(nèi)存”,理論上講程序不會(huì)出錯(cuò),但是該程序的可讀性很差。所以new/delete,malloc/free必 須配對(duì)使用。
2{
3public?? :
4?????? Obj( ) { cout??<<?? “Initialization”??<<?? endl; }
5???????~ Obj( ) { cout??<<?? “Destroy”??<<?? endl; }
6???????void?? Initialize( ) { cout??<<?? “Initialization”??<<?? endl; }
7??????void?? Destroy( ) { cout??<<?? “Destroy”??<<?? endl; }
8};
9
10void?? UseMallocFree( )
11{
12?????? Obj???* a??=?? (obj??* ) malloc( sizeof ( obj ) );?????//?? allocate memory
13?????? a -> Initialize();?????????????????????????????????????????????????//?? initialization
14???????// …
15?????? a -> Destroy();?????????????????????????????????????????????????// deconstruction
16?????? free(a);???????????????????????????????????????????????????????????// release memory
17}
18
19void?? UseNewDelete( void )
20{
21???? Obj???* a??=???new?? Obj;???????????????????????????????????????????
22?????// …
23???? delete a;
24}
類似看法2:
區(qū)別: 1. new 自動(dòng)計(jì)算需要分配的空間,而malloc要手動(dòng)計(jì)算分配的空間。 ????????????? 2. new 是類型安全的,而malloc不是。 ??? 如: int * p = new double[3]; //編譯時(shí)能夠檢查出錯(cuò)誤 ??????????? int* p = malloc(n*sizeof(double));//編譯時(shí)不能夠檢查出錯(cuò)誤 ???????????? 3. malloc/free需要庫文件支持,而new/delete不用。 ??????????? 4. operator new 對(duì)應(yīng)于malloc, 但operator new 可以重載,可以自定義內(nèi)存分配策略,甚至不做內(nèi)存分配。但malloc做不到。 ???????????? 5. new 能為非內(nèi)部數(shù)據(jù)分配動(dòng)態(tài)內(nèi)存,而malloc不能。?? ??????????? 那為什么有了new/delete,還要malloc/free呢? 1. malloc/free 是C++/C 語言的標(biāo)準(zhǔn)庫函數(shù),只能夠用來為內(nèi)部數(shù)據(jù)類型分配空間,new/delete是C++的運(yùn)算符,他們都能夠用于申請(qǐng)動(dòng)態(tài)內(nèi)存和釋放內(nèi)存。 2. 由于malloc/free不能用來滿足動(dòng)態(tài)對(duì)象的要求,對(duì)象在創(chuàng)建的同時(shí)要自動(dòng)執(zhí)行構(gòu)造函數(shù),對(duì)象在消亡的時(shí)候需要自 ...轉(zhuǎn)載于:https://www.cnblogs.com/eagleking0318/archive/2011/10/01/6521214.html
總結(jié)
以上是生活随笔為你收集整理的new/delete与malloc/free的区别和联系的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SmartArt使用
- 下一篇: 尽量使用int型的列类型