析構函式做最後的「清場工作」,
一般當派生類物件從記憶體中撤銷時,先呼叫派生類的析構函式,再呼叫基類析構函式;
但,若用new建立了臨時物件,在用delete撤銷物件是,系統會只執行基類的析構函式,而不執行派生類的析構函式。
如果將基類的析構函式宣告為虛函式,由基類所有派生類的析構函式自動成為虛函式(即使析構函式名不同)。
將析構函式加上vitual,實現具體物件的動態關聯
,在執行階段,先呼叫派生類析構,在呼叫基類析構
例子1:#include
//using namespace std;
class a
; a::~a()
class b : public a
; b::~b()
int main()
輸出結果為delete a
例子2:
#include
using namespace std;
class a
};class b:public a
};int main()
結果為 b a
析構函式呼叫順序
設已經有a,b,c,d4個類的定義,程式中a,b,c,d析構函式呼叫順序為?c c voidmain 這道題主要考察的知識點是 全域性變數,靜態區域性變數,區域性變數空間的堆分配和棧分配 解題思路 其中全域性變數和靜態區域性變數時從靜態儲存區中劃分的空間 未初始化為bss,已初始化為資料段 二者的區...
析構函式的呼叫順序
如果是多個物件,呼叫建構函式的次序與呼叫析構函式的次序相反 對於不同作用域和儲存類別的物件,建構函式he析構函式的呼叫順序 全域性物件 不同作用域和儲存類別的物件建構函式和析構函式的呼叫順序 在寫這個 時遇到了乙個問題,幾個警告 我使用的編譯器是visual studio 2019 出現了乙個錯誤 ...
C 析構函式的呼叫順序
如果指標指向基類,但是指標在執行時指向派生類,則該基類必須具有虛擬析構函式,以便破壞派生類。如果沒有虛擬析構函式,則只會執行基類的析構函式。比如 base baseptr baseptr new derived 1 如果沒有新增virtual,也就是沒有虛擬析構函式,看下面 示例 include u...