我們知道,用c++開發的時候,用來做基類的類,其析構函式一般都是虛函式。可是,為什麼要這樣做呢?下面用乙個小例子來說明:
有下面的兩個類:
class base
;virtual ~base();
virtual void dosomething() ;
};class derived : public base
;~derived();
void dosomething() ;
};base *pbase = new derived();
pbase->dosomething();
delete pbase;
以上**的輸出結果是:
do something in class derived!
output from the destructor of class derived!
output from the destructor of class base!
這個很簡單,非常好理解。但是,如果把類base析構函式前的virtual去掉,那輸出結果就是下面的樣子了:
do something in class derived!
output from the destructor of class base!
也就是說,類derived的析構函式根本沒有被呼叫!一般情況下類的析構函式裡面都是釋放記憶體資源,而析構函式不被呼叫的話就會造成記憶體洩漏。我想所有的c++程式設計師都知道這樣的危險性。當然,如果在析構函式中做了其他工作的話,那你的所有努力也都是白費力氣。
所以,文章開頭的那個問題的答案就是:這樣做是為了當用乙個基類的指標刪除乙個派生類的物件時,派生類的析構函式會被呼叫。
當然,並不是要把所有類的析構函式都寫成虛函式。因為當類裡面有虛函式的時候,編譯器會給類的物件新增乙個虛函式表,裡面來存放虛函式指標,這樣就會增加類的物件的儲存空間。所以,只有當乙個類被用來作為基類的時候,才把析構函式寫成虛函式。關於虛函式表,請參看另一篇博文 「c++虛函式表解析」。
C 中虛析構函式作用
我們知道,用c 開發的時候,用來做基類的類的析構函式一般都是虛函式。可是,為什麼要這樣做呢?下面用乙個小例子來說明 有下面的兩個類 class clxbase virtual clxbase virtual void dosomething class clxderived public clxba...
C 中虛析構函式的作用
我們知道,用c 開發的時候,用來做基類的類的析構函式一般都是虛函式。可是,為什麼要這樣做呢?下面用乙個小例子來說明 有下面的兩個類 class clxbase virtual clxbase virtual void dosomething class clxderived public clxba...
C 中虛析構函式的作用
收藏 我們知道,用c 開發的時候,用來做基類的類的析構函式一般都是虛函式。可是,為什麼要這樣做呢?下面用乙個小例子來說明 有下面的兩個類 class clxbase virtual clxbase virtual void dosomething class clxderived public cl...