(1)析構函式定義為虛函式時:基類指標可以指向派生類的物件(多型性),如果刪除該指標delete p;就會呼叫該指標指向的派生類析構函式,而派生類的析構函式又自動呼叫基類的析構函式,這樣整個派生類的物件完全被釋放。
(2)析構函式不定義為虛函式時:編譯器實施靜態繫結,在刪除基類指標時,只會呼叫基類的析構函式而不呼叫派生類析構函式,這樣就會造成派生類物件析構不完全。
下面看幾個例子
#includeusing namespace std;
class clxbase;
~clxbase() ;
void dosomething() ;
};class clxderived : public clxbase;
~clxderived() ;
void dosomething() ;
};int main()
注:派生類指標操作派生類物件,基類析構函式不是虛函式,此時會先是否派生類的資源,再釋放基類的資源,這裡資源就不會出現洩漏的情況。
#includeusing namespace std;
class clxbase;
~clxbase() ;
void dosomething() ;
};class clxderived : public clxbase;
~clxderived() ;
void dosomething() ;
};int main()
注:基類指標操作派生類物件,基類析構函式不是虛函式:此時只是釋放了基類的資源,而沒有呼叫派生類的析構函式。呼叫dosomething()函式執行的也是基類定義的函式。這樣的刪除只能夠刪除基類物件,而不能刪除子類物件,形成了刪除一半角象,造成記憶體洩漏。
#includeusing namespace std;
class clxbase;
// 定義為虛函式
virtual ~clxbase() ;
virtual void dosomething() ;
};class clxderived : public clxbase;
~clxderived() ;
void dosomething() ;
};int main()
注:基類指標操作派生類物件,基類析構函式是虛函式:此時釋放了派生類的資源,再呼叫基類的析構函式。呼叫dosomething()函式執行的也是派生類定義的函式。
在公有繼承中,基類對派生類及其物件的操作,只能影響到那些從基類繼承下來的成員。如果想要用基類對非繼承成員進行操作,則要把基類的這個函式定義為虛函式。
析構函式自然也應該如此:如果它想析構子類中的重新定義或新的成員及物件,當然也應該宣告為虛的。
如果不需要基類對派生類及物件進行操作,則不能定義虛函式,因為這樣會增加記憶體開銷.當類裡面有定義虛函式的時候,編譯器會給類新增乙個虛函式表,裡面來存放虛函式指標,這樣就會增加類的儲存空間。所以,只有當乙個類被用來作為基類的時候,並且有使用到基類指標操作派生類的情況時,才把析構函式寫成虛函式。
C 析構函式 虛析構函式
1.為什麼要定義虛析構函式?如果有乙個帶有虛函式功能的類,則它需要乙個虛析構函式,原因如下 1 如果乙個類有虛函式功能,它經常作為乙個基類使用 2 如果它是乙個基類,它的派生類經常使用new來分配 3 如果乙個派生類物件使用new來分配,並且通過乙個指向它的基類的指標來控制,那麼它經常通過乙個指向它...
C 虛析構函式 純虛析構函式
虛析構函式 析構函式的工作方式是 最底層的派生類 most derived class 的析構函式最先被呼叫,然後呼叫每乙個基類的析構函式。因為在c 中,當乙個派生類物件通過使用乙個基類指標刪除,而這個基類有乙個非虛的析構函式,則結果是未定義的。執行時比較有代表性的後果是物件的派生部分不會被銷毀。然...
C 虛析構函式 純虛析構函式
虛析構函式 析構函式的工作方式是 最底層的派生類 most derived class 的析構函式最先被呼叫,然後呼叫每乙個基類的析構函式。因為在c 中,當乙個派生類物件通過使用乙個基類指標刪除,而這個基類有乙個非虛的析構函式,則結果是未定義的。執行時比較有代表性的後果是物件的派生部分不會被銷毀。然...