面試時被問到了虛析構函數的使用,特此記錄
?
首先我們寫兩個類:
#ifndef CLX_H #define CLX_H #include <iostream> class ClxBase { public: ClxBase() {std::cout << "clx_base has been created" << std::endl;} virtual ~ClxBase() {std::cout << "clx_base has been destroyed" << std::endl;} virtual void dosomething() {std::cout << "clx_base dosomething..." << std::endl;} }; class ClxDerived : public ClxBase { public: ClxDerived() {std::cout << "clx_derived has been created" << std::endl;} ~ClxDerived(){std::cout << "clx_derived has been destroyed" << std::endl;} void dosomething() {std::cout << "clx_derived dosomething..." << std::endl;} }; #endif
?
指明了,父類的析構函數是虛類型。
?
調用代碼:
ClxBase *clx = new ClxDerived; clx->dosomething(); delete clx;
?
運行結果如下:
注意類加載時的順序和析構的順序是剛好相反的。析構是總是從子類開始,然后再回收父類,符合編程要求。
?
如果將父類中規(guī)定的虛類型去掉,即
class ClxBase { public: ClxBase() {std::cout << "clx_base has been created" << std::endl;} ~ClxBase() {std::cout << "clx_base has been destroyed" << std::endl;} virtual void dosomething() {std::cout << "clx_base dosomething..." << std::endl;} };
這樣,只會執(zhí)行基類的析構函數,而派生類的析構函數不會執(zhí)行。 相當于沒有重載。
運行效果如下:
當基類的析構函數為虛函數時,無論指針指的是同一類族中的哪一個類對象,系統(tǒng)會采用動態(tài)關聯(lián),調用相應的析構函數,對該對象進行清理工作。
如果將基類的析構函數聲明為虛函數時,由該基類所派生的所有派生類的析構函數也都自動成為虛函數,即使派生類的析構函數與基類的析構函數名字不相同。
最好把基類的析構函數聲明為虛函數。這將使所有派生類的析構函數自動成為虛函數。這樣,如果程序中顯式地用了delete運算符準備刪除一個對象,而delete運算符的操作對象用了指向派生類對象的基類指針,則系統(tǒng)會調用相應類的析構函數。
虛析構函數的概念和用法很簡單,但它在面向對象程序設計中卻是很重要的技巧。
專業(yè)人員一般都習慣聲明虛析構函數,即使基類并不需要析構函數,也顯式地定義一個函數體為空的虛析構函數,以保證在撤銷動態(tài)分配空間時能得到正確的處理。
構造函數不能聲明為虛函數。這是因為在執(zhí)行構造函數時類對象還未完成建立過程,當然談不上函數與類對象的綁定。
?
更多文章、技術交流、商務合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
