虛析構函式

2021-09-30 07:44:50 字數 923 閱讀 7665

虛析構函式是為了解決這樣的乙個問題:基類的指標指向派生類物件,並用基類的指標刪除派生類物件。

如果某個類不包含虛函式,那一般是表示它將不作為乙個基類來使用。當乙個類不準備作為基類使用時,使析構函式為虛一般是個壞主意。因為它會為類增加乙個虛函式表,使得物件的體積翻倍,還有可能降低其可移植性。   所以基本的一條是:無故的宣告虛析構函式和永遠不去宣告一樣是錯誤的。實際上,很多人這樣總結:當且僅當類裡包含至少乙個虛函式的時候才去宣告虛析構函式。   抽象類是準備被用做基類的,基類必須要有乙個虛析構函式,純虛函式會產生抽象類,所以方法很簡單:在想要成為抽象類的類裡宣告乙個純虛析構函式。   這裡是乙個例子:   class awov ;   這個類有乙個純虛函式,所以它是抽象的,而且它有乙個虛析構函式,所以不會產生析構函式問題。但這裡還有一件事:必須提供純虛析構函式的定義:   awov::~awov() {} // 純虛析構函式的定義   這個定義是必需的,因為虛析構函式工作的方式是:最底層的派生類的析構函式最先被呼叫,然後各 個基類的析構函式被呼叫。這就是說,即使是抽象類,編譯器也要產生對~awov的呼叫,所以要保證為它提供函式體。如果不這麼做,鏈結器就會檢測出來,最 後還是得回去把它添上。   注意:如果宣告虛析構函式為inline,將會避免呼叫它們時產生的開銷,但編譯器還是必然會在什麼地方產生乙個此函式的拷貝。

什麼時候才要用虛析構函式呢?通常情況下,程式設計師的經驗是,當類中存在虛函式時要把析構函式寫成virtual,因為類中存在虛函式,就說明它有想要讓基類指標或引用指向派生類物件的情況,此時如果派生類的建構函式中有用new動態產生的記憶體,那麼在其析構函式中務必要delete這個資料,但是一般的像以上這種程式,這種操作只呼叫了基類的析構函式,而標記成虛析構函式的話,系統會先呼叫派生類的析構函式,再呼叫基類本身的析構函式。不知道你有沒有懂,希望可以幫到你。 

一般情況下,在類中有指標成員的時候要寫copy建構函式,賦值操作符過載和析構函式。

C 虛析構函式 純虛析構函式

虛析構函式 析構函式的工作方式是 最底層的派生類 most derived class 的析構函式最先被呼叫,然後呼叫每乙個基類的析構函式。因為在c 中,當乙個派生類物件通過使用乙個基類指標刪除,而這個基類有乙個非虛的析構函式,則結果是未定義的。執行時比較有代表性的後果是物件的派生部分不會被銷毀。然...

C 虛析構函式 純虛析構函式

虛析構函式 析構函式的工作方式是 最底層的派生類 most derived class 的析構函式最先被呼叫,然後呼叫每乙個基類的析構函式。因為在c 中,當乙個派生類物件通過使用乙個基類指標刪除,而這個基類有乙個非虛的析構函式,則結果是未定義的。執行時比較有代表性的後果是物件的派生部分不會被銷毀。然...

C 虛析構函式 純虛析構函式

虛析構函式 析構函式的工作方式是 最底層的派生類 most derived class 的析構函式最先被呼叫,然後呼叫每乙個基類的析構函式。因為在c 中,當乙個派生類物件通過使用乙個基類指標刪除,而這個基類有乙個非虛的析構函式,則結果是未定義的。執行時比較有代表性的後果是物件的派生部分不會被銷毀。然...