? ? 1、malloc與free是C語言的標準庫函數,new/delete是C++的運算符。它們都可用于申請動態內存和釋放內存。
2、對于非內部數據類型的對象而言,光用maloc/free無法滿足動態對象的要求。對象在創建的同時要自動執行構造函數,對象在消亡之前要自動執行析構函數。由于malloc/free是庫函數而不是運算符,不在編譯器控制權限之內,不能夠把執行構造函數和析構函數的任務強加于malloc/free。
3、因此C++語言需要一個能完成動態內存分配和初始化工作的運算符new,以一個能完成清理與釋放內存工作的運算符delete。
4、new 是個操作符,和什么”+”,”-”,”=”…有一樣的地位.
5、new是保留字,不需要頭文件支持.malloc需要頭文件庫函數支持.?
????? 6、new/delete是可以重載的,而重載之后,就成為了函數當new/delete在類中被重載的時候,可以自定義申請過程,比如記錄所申請內存的總長度,以及跟蹤每個對象的指針。
7、new 建立的是一個對象,malloc分配的是一塊內存. new建立的對象你可以把它當成一個普通的對象,用成員函數訪問,不要直接訪問它的地址空間。
8、malloc分配的是一塊內存區域,就用指針訪問好了,而且還可以在里面移動指針
?????9、new/delete,其實內部也調用了malloc/free
?????10、malloc在申請內存的時候,必須要提供申請的長度,而且返回的指針是void*型,必須要強轉成需要的類型。free和delete可以釋放NULL指針。
???? 11、都必須配對使用。
???? 12、對類類型,delete一個數組時(比如,delete []sa;),要為每一個數組元素調用析構函數。但對于delete表達式(比如,這里的delete []sa),它并不知道數組的元素個數(只有new函數和delete函數知道)。因此,必須有一種手段來告訴delete表達式的數組大小是多少。
???? 13、 使用new動態分配內存:若沒有足夠內存,則new返回0(空值指針null pointer)
???? 14、不要使用delete釋放不是new分配的內存,delete釋放指針指向的內存,但不會刪除指針本身
?????15、創建數組時的靜態聯編與動態聯編:數組聲名int a[10], 靜態聯編,數組的長度在編譯時確定;?用new[]創建數組,動態聯編,運行時為數組分配內存空間。動態-運行時分配內存。
舉幾個簡單的例子吧:
int* pn = (int*)malloc(sizeof(int));
*pn = 15;
free(pn);
pn = NULL; // 置空
free(pn); // OK,沒有問題
double* pd = new double;
*pd = 212.211;
delete = pd;
short* ps = new short[128]; // new出一個數組來
ps[1] = 1231;
ps[11] = 1111;
delete[] ps;? // 請注意delete的語法。
// 以下是一個重載new操作符的例子,一般來說是不會用到的,除非要設計一個編譯器之類的東西。
class Sample
{
public:
??? static CSample* operator= new()
??? {
??????? CSample* p = (CSample*)malloc(size(Sample));
??????? return p;
??? }
}
?
??????
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
