C 基類析構函式為什麼要定義為虛函式

2021-09-25 09:52:07 字數 1491 閱讀 8690

在c++實現多型裡,有乙個關於 析構函式的重寫問題:基類中的析構函式如果是虛函式,那麼派生類的析構函式就重寫了基類的析構函式。這裡他們的函式名不相同,看起來違背了重寫的規則,但實際上編譯器對析構函式的名稱做了特殊處理,編譯後析構函式的名稱統一處理成destructor。那麼為什麼要把基類中的析構函式寫成虛函式呢?

原因:當基類指標指向派生類的時候,若基類析構函式不宣告為虛函式,在析構時,只會呼叫基類而不會呼叫派生類的析構函式,從而導致記憶體洩露。舉個例子:

class a 

~a()

void work()

};//基類

class b :public a

~b()

void work()

}; //派生類

int main()

執行之:

可以看到在delete p的時候只呼叫了基類a的析構函式,並沒有呼叫派生類b的析構函式,導致記憶體釋放並不完全,出現記憶體洩漏的問題。

class a 

virtual ~a()

void work()

};//基類

class b :public a

~b() //在派生類中重寫的成員函式可以不加virtual關鍵字

void work()

};//派生類

int main()

執行之:

可以看到這次在delete p的時候呼叫了派生類的析構函式,因為在呼叫派生類的析構函式後會自動呼叫基類的析構函式,這樣整個派生類的物件被完全釋放。

另外上面兩個過程中我們發現執行 "p->work();" 時,也就是p在呼叫同名成員函式的時候,呼叫的始終是基類的成員函式,這是因為基類的成員函式覆蓋了派生類的同名成員函式,如果想要呼叫派生類的成員函式,同樣將work()設定為虛函式即可。

記憶體切割:

為什麼析構函式要定義為虛函式

include using namespace std class a virtual a a void fun protected private class b public a b int main 當a的析構函式宣告為虛函式時,執行結果如下 當a的析構函式為普通函式時,執行結果如下 對比可得...

析構函式為什麼要定義為虛函式

1.為什麼基類的析構函式是虛函式?在實現多型時,當用基類操作派生類,在析構時防止只析構基類而不析構派生類的狀況發生。下面 網路 源位址 a.第一段 includeusing namespace std class clxbase clxbase void dosomething class clxd...

C 基類的析構函式為什麼需要定義為虛函式

主要是因為當通過父類指標 引用,刪除子類時由於父類析構函式沒有定義為虛函式,不能表現出多型性。所以子類的析構函式不能被呼叫,從而造成記憶體洩露。include include includeusing namespace std class base base cout base destructo...