本篇內(nèi)容介紹了“C++中new和malloc的區(qū)別及使用”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),南和企業(yè)網(wǎng)站建設(shè),南和品牌網(wǎng)站建設(shè),網(wǎng)站定制,南和網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,南和網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。定義上:malloc memory allocation 動態(tài)內(nèi)存分配 是c中的一個函數(shù)
使用方法:
extern void *malloc(unsigned int num_bytes)
extern void *malloc(unsigned int num_bytes)
um_bytes內(nèi)存塊字節(jié)長度。
內(nèi)存塊大小確定:malloc是通過我們計算然后得到一塊新內(nèi)存,然后指定數(shù)據(jù)類型并且內(nèi)存值也是隨機的。
使用時:需要引入頭文件庫函數(shù) stdlib.h 或是 malloc.h(malloc.h與alloc.h一致)。
內(nèi)存分配位置:堆中動態(tài)分配的內(nèi)存。
具體分配過程:由程序向操作系統(tǒng)申請,操作系統(tǒng)遍歷空閑結(jié)點鏈表,將第一個大于申請空間的堆結(jié)點分配給程序,然后將空閑結(jié)點鏈表中此節(jié)點刪掉。
成功分配:返回值為指向被分配內(nèi)存的指針。
失敗分配:返回值為空NULL。
返回類型:void* (未確定類型的指針)。
void*類型可以通過強制類型轉(zhuǎn)換轉(zhuǎn)換為任意其他類型(因為用戶存儲數(shù)據(jù)類型未知,由用戶決定數(shù)據(jù)類型)。
內(nèi)存塊釋放:free()函數(shù) 將內(nèi)存還給程序或操作系統(tǒng)。
注意:malloc與free都屬于c/c++標準庫函數(shù),在使用時應(yīng)該配對 申請之后不釋放就會有可能發(fā)生內(nèi)存泄漏。
使用free時需要檢查指針是否為空。
ew 是c++中的運算符(其地位等同于“+”,“=”)。
在使用:new時不止分配內(nèi)存,還會進行初始化,執(zhí)行相應(yīng)構(gòu)造函數(shù),初始化時需要指定數(shù)據(jù)類型。
內(nèi)存分配位置:自由存儲區(qū)為對象分配內(nèi)存。
使用時:無需引入頭文件,new是保留字?
ew 和 delete 是配對使用的。
在使用delete時注意將指針置為0,否則會形成懸垂指針(指針所指內(nèi)存已被釋放,仍指向該內(nèi)存),造成錯誤?
ew 可以看做是malloc 加 構(gòu)造函數(shù)的執(zhí)行,就是new更高級一些?
ew的幾種用法:
1 int *p=new int; //在自由存儲區(qū)開辟一個int變量 2 int *p=new int[10];//在自由存儲區(qū)開辟一個int數(shù)組,有10個元素 3 int *p=new int(10);//在自由存儲區(qū)開辟一個int變量,并初始化為10
釋放內(nèi)存時無需檢查是否為空。
如果p等于NULL,則delete p不作任何事情。由于之后可以得到測試,并且大多數(shù)的測試方法論都強制顯式測試每個分支點,因此你不應(yīng)該加上多余的 if 測試。
錯誤的:
1 if (p != NULL) 2 delete p; 3正確的:delete
面試時可能會問到的問題:
1)它們都可用于申請動態(tài)內(nèi)存和釋放內(nèi)存?
2)malloc是庫函數(shù)只能作用于內(nèi)部數(shù)據(jù)類型,對于非內(nèi)部數(shù)據(jù)動態(tài)對象而言,就不能完成對象的初始化與銷毀,即執(zhí)行構(gòu)造函數(shù)與析構(gòu)函數(shù),而new 與 delete此類運算符就能夠在編譯器的控制權(quán)限內(nèi)完成,對象的初始化與銷毀任務(wù),即執(zhí)行構(gòu)造函數(shù)與析構(gòu)函數(shù)?
既然new/delete的功能完全覆蓋了malloc/free,為什么C++不把malloc/free淘汰出局呢?這是因為C++程序經(jīng)常要調(diào)用C函數(shù),而C程序只能用malloc/free管理動態(tài)內(nèi)存?
我們不要企圖用malloc/free來完成動態(tài)對象的內(nèi)存管理,應(yīng)該用new/delete?由于內(nèi)部數(shù)據(jù)類型的“對象”沒有構(gòu)造與析構(gòu)的過程,對它們而言malloc/free和new/delete是等價的?
注意:如果用free釋放“new創(chuàng)建的動態(tài)對象”,那么該對象因無法執(zhí)行析構(gòu)函數(shù)而可能導(dǎo)致程序出錯?
如果用delete釋放“malloc申請的動態(tài)內(nèi)存”,結(jié)果也會導(dǎo)致程序出錯,但是該程序的可讀性很差?所以new/delete必須配對使用,malloc/free也一樣?
零值指針,是值是0的指針,可以是任何一種指針類型,可以是通用變體類型void*也可以是char*,int*等等? 空指針,其實空指針只是一種編程概念,就如一個容器可能有空和非空兩種基本狀態(tài),而在非空時可能里面存儲了一個數(shù)值是0,因此空指針是人為認為的指針不提供任何地址訊息?
內(nèi)存泄漏對于malloc或者new都可以檢查出來的,區(qū)別在于new可以指明是那個文件的那一行,而malloc沒有這些信息?
“C++中new和malloc的區(qū)別及使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!