1樓:du瓶邪
簡單的測試:
c/c++ code
// 此處t是不完整型別 , 編譯會出錯
typedef char t;
typedef char type_must_be_complete[ sizeof(t)? 1: -1 ];
(void) sizeof(type_must_be_complete);
// 此處t是完整型別 , 編譯不會出錯
typedef char t[1];
typedef char type_must_be_complete[ sizeof(t)? 1: -1 ];
(void) sizeof(type_must_be_complete);
2樓:
r指向的是p,而p是直接定義的,不能用delete來刪除。程式執行會出錯的。
比如 int a; int *r=&a; delete r; 一樣。
程式會除錯的原因:
因為class a的賦值建構函式中是將x指標進行賦值,所以在main()函式中b變數實際是將a的x地址複製到b,即b.x=a.x;如果開啟delete a;則會釋放x指向的記憶體,隨後b變數在main()函式結束時,自動呼叫解構函式,再次去delete x,這是x實際指向的記憶體已經被釋放了,所以出錯。
3樓:匿名使用者
delete 只是c++封裝了一個類似操作符的東西傳入的是 記憶體的首地址
顯然你傳入的r 不是p指向的首地址,所以不掛就萬幸了你想吧, 拿一個無效的地址去查連結串列(記憶體按塊連結起來的),會怎樣把delete *r; 還差不多
4樓:匿名使用者
delete是刪除該指標所指向的記憶體內容。
delete r是刪除了變數p的記憶體。但new int所申請的記憶體還在。
5樓:匿名使用者
r--->p--->int
所以delete r是刪掉p記憶體,與int無關,但由於p沒啦~所以你也取不了int了
c++ 中delete一指標後,該指標的是什麼?是 null 嗎?
6樓:
delete一個指標之後,只是**指標指向位置的空間,而指標本身的值不變。你需要手工將其賦值為null。
另外delete null的話不會有任何事情發生。
7樓:匿名使用者
不是 delete後就變成懸垂指標 就是沒有用的指標了最好自己將他指向null
如 delete p;
p = 0; // 0 == null
這樣就安全了。
否則會產生不必要的後遺症(在大型程式裡你就會懊惱了,當然這個我也不太懂了)
8樓:匿名使用者
這書我看過了 c++沉思錄 c++primer 上面都提到智慧指標 是這樣的:u_ptr這個類算是**類吧(有時叫它控制代碼類 其實我也不知道為什麼) 因為它有計數 計數的是有多少個物件是u_ptr類**的類(原始的) 每建立或者複製這種型別的物件 實際上在u_ptr中的計數加1(有多少個原始的類型別的物件指向u_ptr) 只有一個u_ptr指向原始的類(或是別的) 注意:當u_ptr中的計數為0時就是沒有物件對向他 所以執行delete p 而**類本身沒有動態申請堆空間 釋放的只是原始類(u_ptr指向的)申請的空間 我覺得你沒有弄清楚指標p和u_ptr之間的區別
會的!p成為野指標 如果在訪問p將出錯 因為p指向的記憶體空間以不在 但p還是指向原來的地方啊…
9樓:匿名使用者
c++ 中delete一指標後,該指標為野指標。其值不變,還是指向原來的單元,但若訪問這個單元,結果是無法預料的。
10樓:匿名使用者
delete刪除的只是該指標指向的記憶體,該指標變成一個野指標,需要重置為null。
11樓:匿名使用者
野指標,需要置null
c++中的delete到底是清空什麼?是指標本身還是指標所指向的值?
12樓:匿名使用者
c++的delete要執行兩個步驟:
1 按照指標型別,呼叫該類的解構函式。
(這個是c的free沒有的功能)。
2 根據指標型別,釋放相應寬度的記憶體空間。(類似c的free)。
從這個題目來說,delete是是否指標所指向的物件。而不是釋放指標本身。
一般而言,delete p;以後最後跟一個 p=null;避免無效指標的二次訪問。
13樓:匿名使用者
主要是**記憶體,目的是為了告訴作業系統程式對這部分記憶體不在使用了 讓作業系統可以把這部分記憶體拿去做其它事情
14樓:
是清空記憶體,是指:指標指向的值的空間(記憶體),用於**記憶體
15樓:青檸
new 和 delete 是一組 new申請記憶體,delete釋放記憶體,記得將釋放的指標置為null
16樓:匿名使用者
指向的值,如果不用delete,指標本身沒了,但是所指向的空間沒有被釋放。
c中delete一指標後,該指標的是什麼 是NULL嗎
delete一個指標之後,只是 指標指向位置的空間,而指標本身的值不變。你需要手工將其賦值為null。另外delete null的話不會有任何事情發生。不是 delete後就變成懸垂指標 就是沒有用的指標了最好自己將他指向null 如 delete p p 0 0 null 這樣就安全了。否則會產生...
關於delete後,給指標NULL的問題,vc
在函式裡面置null,不能改變str的值,傳參拷貝問題 可以在外面調這個函式後置,不置的話肯定會有問題的,就是多個地方都使用該指標,你這邊釋放了,那邊不知道,一判斷還不空,那玩笑可就開大了 最好的bai習慣是 null,為什麼呢?因為怕這du這個指標亂指,然zhi後你後面不 dao小心又用了,專那可...
C 中的delete到底是清空什麼?是指標本身還是指標所指向的值
c 的delete要執行兩個步驟 1 按照指標型別,呼叫該類的解構函式。這個是c的free沒有的功能 2 根據指標型別,釋放相應寬度的記憶體空間。類似c的free 從這個題目來說,delete是是否指標所指向的物件。而不是釋放指標本身。一般而言,delete p 以後最後跟一個 p null 避免無...