C++ new到底new什麼

VS2010-Debug版本
 1 9: int *obj = new int(6);  2 00F714CE push 4 //壓棧
 3 00F714D0 call operator new (0F711EAh) //調用new函數返回分配的地址addr --- 0F711EAh是指令 jmp operator new 的地址
 4 00F714D5 add esp,4 //恢復棧
 5 00F714D8 mov dword ptr [ebp-0F8h],eax //把返回的地址addr賦給起始地址爲ebp-0F8h的內存空間
 6 00F714DE cmp dword ptr [ebp-0F8h],0 //判斷分配是否成功
 7 00F714E5 je main+51h (0F71501h)  //若是不成功跳往0x0F71501h   
 8 00F714E7 mov eax,dword ptr [ebp-0F8h] //起始地址爲ebp-0F8h 的內存空間(addr)賦值給eax
 9 00F714ED mov dword ptr [eax],6 //把以起始地址爲eax的內存空間(addr)置成6
10 00F714F3 mov ecx,dword ptr [ebp-0F8h] //起始地址爲ebp-0F8h 的內存空間(addr)賦值給ecx
11 00F714F9 mov dword ptr [ebp-100h],ecx //ecx的值(addr)賦給起始地址爲ebp-100h的內存空間
12 00F714FF jmp main+5Bh (0F7150Bh) //無條件跳轉到0x0F7150B
13 00F71501 mov dword ptr [ebp-100h],0 //起始地址爲ebp-100h的內存空間置爲0---分配失敗的狀況
14 00F7150B mov edx,dword ptr [ebp-100h] //起始地址爲ebp-100h的內存空間(addr)賦值給edx
15 00F71511 mov dword ptr [obj],edx  //把edx的內容(addr)賦值給obj爲起始地址的內存空間a
16 10: delete obj;
17 00F71514 mov eax,dword ptr [obj]  //把obj爲起始地址的內存空間送往eax
18 00F71517 mov dword ptr [ebp-0ECh],eax //eax送往以ebp-0ECh爲起始地址的內存空間
19 00F7151D mov ecx,dword ptr [ebp-0ECh]  //以ebp-0ECh爲起始地址的內存空間送往ecx
20 00F71523 push ecx //ecx壓棧
21 00F71524 call operator delete (0F710A0h)
22 00F71529 add esp,4  
23 11:int *obj2 = new int(7);
24 與分配obj相同

 

 此時輸出*obj,會獲得「7」。
why? obj原本是指向分配的地址addr_obj, 刪除操做就是刪除掉addr_obj中的內容,釋放addr_obj內存,可是obj自己仍是指向它的
當咱們給obj2分配空間時,new函數會返回第一個可用的地址,也就是剛纔釋放的addr_obj,此時obj仍然指向該地址,因此獲得上述結果。
這樣作雖然偶爾會正確,可是後患無窮!!!
 
 
addr的通過的地方
eax -> ptr [ebp-0F8h] -> ecx ->  ptr [ebp-100h] -> edx -> ptr[obj]
 
new函數所要作的
1. 調用對象的構造函數,分配空間,返回地址addr
2. 把返回的地址addr賦值給指針對象
相關文章
相關標籤/搜索