首先看看下面這個簡單的**:
#include
#include
using namespace std;
class pet
;class dog:public pet
;pet::pet():i(1)
{cout<<"new pet"pet *p=new dog;
。。。。
delete p;
當基類中的析構函式沒有被標示為virtual時,只有基類的析構函式被呼叫,如果基類的析構函式被標示為virtual,那麼當用delete作用於p時dog類的析構函式將被呼叫,同時自動呼叫基類的析構函式.
由此可見只要基類的析構函式標示為virtual,那麼所有占用的記憶體空間都將被釋放,為防範如上的不測事件,沒有釋放所有的記憶體空間,最好是把析構函式標示為虛函式。
建構函式 析構函式 虛析構函式
說析構函式之前,先說下建構函式。建構函式用來完成對物件的一系列初始化操作,主要作用有 1.給建立的物件建立乙個識別符號 2.為物件資料成員開闢記憶體空間 3.完成物件資料成員的初始化 當並未顯示的定義建構函式時,會生成乙個預設的建構函式,預設建構函式不能完成物件資料成員的初始化,只能給物件建立一識別...
C 析構函式 虛析構函式
1.為什麼要定義虛析構函式?如果有乙個帶有虛函式功能的類,則它需要乙個虛析構函式,原因如下 1 如果乙個類有虛函式功能,它經常作為乙個基類使用 2 如果它是乙個基類,它的派生類經常使用new來分配 3 如果乙個派生類物件使用new來分配,並且通過乙個指向它的基類的指標來控制,那麼它經常通過乙個指向它...
C 虛析構函式 純虛析構函式
虛析構函式 析構函式的工作方式是 最底層的派生類 most derived class 的析構函式最先被呼叫,然後呼叫每乙個基類的析構函式。因為在c 中,當乙個派生類物件通過使用乙個基類指標刪除,而這個基類有乙個非虛的析構函式,則結果是未定義的。執行時比較有代表性的後果是物件的派生部分不會被銷毀。然...