相同點(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)一塊長度為length 的整數(shù)類型的內(nèi)存设联,程序如下:int *p = (int *) malloc(sizeof(int) * length)善已;我們應(yīng)當(dāng)把注意力集中在兩個(gè)要素上:“類型轉(zhuǎn)換”和“sizeof”。
1仑荐、malloc 返回值的類型是void *雕拼,所以在調(diào)用malloc 時(shí)要顯式地進(jìn)行類型轉(zhuǎn)換纵东,將void * 轉(zhuǎn)換成所需要的指針類型粘招。
2、 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 簡單得多煌恢,例如: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这溅。
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ì)使用。