文章講解了在WINDOWS下,最好的方式是用Virtual Alloc分配內(nèi)存,它不是在堆,也不是在棧,而是直接在進(jìn)程地址空間保留一塊內(nèi)存,雖然用起來最不方便。但是速度快,也最靈活。
二、堆和棧的理論知識
2.1申請方式
stack:
由系統(tǒng)自動(dòng)分配。例如,聲明在函數(shù)中一個(gè)局部變量int b;系統(tǒng)自動(dòng)在棧中為b開辟空間heap:
需要程序員自己申請,并指明大小,在c中malloc函數(shù)
如p1=(char*)malloc(10);
在C++中用new運(yùn)算符
如p2=(char*)malloc(10);
但是注意p1、p2本身是在棧中的。
2.2 申請后系統(tǒng)的響應(yīng)
棧:只要棧的剩余空間大于所申請空間,系統(tǒng)將為程序提供內(nèi)存,否則將報(bào)異常提示棧溢出。
堆:首先應(yīng)該知道操作系統(tǒng)有一個(gè)記錄空閑內(nèi)存地址的鏈表,當(dāng)系統(tǒng)收到程序的申請時(shí),會(huì)遍歷該鏈表,尋找第一個(gè)空間大于所申請空間的堆結(jié)點(diǎn),然后將該結(jié)點(diǎn)從空閑結(jié)點(diǎn)鏈表中刪除,并將該結(jié)點(diǎn)的空間分配給程序,另外,對于大多數(shù)系統(tǒng),會(huì)在這塊內(nèi)存空間中的首地址處記錄本次分配的大小,這樣,代碼中的delete語句才能正確的釋放本內(nèi)存空間。另外,由于找到的堆結(jié)點(diǎn)的大小不一定正好等于申請的大小,系統(tǒng)會(huì)自動(dòng)的將多余的那部分重新放入空閑鏈表中。
相關(guān)推薦:
C++等考輔導(dǎo):C++static關(guān)鍵字使用時(shí)的技巧 2009年C++等考輔導(dǎo):類靜態(tài)成員和靜態(tài)成員函數(shù)