cast-expression 引數必須是先前配置給物件的記憶體區塊指標,而物件是使用 新的運算子 所建立。 delete 運算子具有類型 void 的結果,因此不會傳回值。 例如:

CDialog* MyDialog = new CDialog;
// use MyDialog
delete MyDialog;

對未使用 new 配置之物件的指標使用 delete 會產生無法預期的結果。 不過,您可以對值為 0 的指標使用 delete。 此佈建代表如果 new 在失敗時傳回 0,則刪除失敗 new 作業的結果無害。 如需詳細資訊,請參閱 新的和刪除運算子

newdelete 運算子也可以用於內建類型 (包括陣列)。 如果 pointer 指的是陣列,請在 pointer 前面放置空括號 ([]):

int* set = new int[100];
//use set[]
delete [] set;

對物件使用 delete 運算子會取消配置其記憶體。 在刪除物件之後將指標取值的程式可能會有無法預期的結果或損毀。

delete 來取消配置 C++ 類別物件的記憶體時,會在取消配置物件的記憶體之前呼叫物件的解構函式 (如果物件具有解構函式)。

如果 delete 運算子的運算元是可修改的 l 值,其值在刪除物件之後為未定義。

如果指定了 /sdl (啟用其他安全性檢查) 編譯器選項,則 delete 運算子的運算元會在刪除物件之後設定為無效的值。

使用 delete

刪除運算子有兩種語法變化:一種用於單一物件,另一種用於物件陣列。 下列程式碼片段會示範兩者不同之處:

// expre_Using_delete.cpp
struct UDType
int main()
   // Allocate a user-defined object, UDObject, and an object
   //  of type double on the free store using the
   //  new operator.
   UDType *UDObject = new UDType;
   double *dObject = new double;
   // Delete the two objects.
   delete UDObject;
   delete dObject;
   // Allocate an array of user-defined objects on the
   // free store using the new operator.
   UDType (*UDArr)[7] = new UDType[5][7];
   // Use the array syntax to delete the array of objects.
   delete [] UDArr;

下列兩種情況會產生未定義的結果:對物件使用陣列形式的刪除 (delete []),以及對陣列使用非陣列形式的刪除。

如需使用 delete 的範例,請參閱新的運算子

delete 運作方式

刪除運算子會叫用函式運算子刪除

對於不是類別類型 (類別, 結構, 或 聯盟) 的物件,會叫用全域刪除運算子。 對於類別類型的物件,如果刪除運算式是以一元範圍解析運算子 (::) 開頭,則會在全域範圍中解析解除配置函式的名稱。 否則,如果指標不是 Null,delete 運算子會在解除配置記憶體之前叫用物件的解構函式。 delete 運算子可以依類別來定義;如果指定類別沒有這類定義,會叫用全域 delete 運算子。 如果使用刪除運算式來解除配置靜態類型包含虛擬解構函式的類別物件,則會透過該物件之動態類型的虛擬解構函式來解析解除配置函式。

具有一元運算子的運算式
new 和 delete 運算子

即將登場:在 2024 年,我們將逐步淘汰 GitHub 問題作為內容的意見反應機制,並將它取代為新的意見反應系統。 如需詳細資訊,請參閱:https://aka.ms/ContentUserFeedback

提交並檢視相關的意見反應