虛析構(gòu)函數(shù)
在C++中,不能把構(gòu)造函數(shù)定義為虛構(gòu)造函數(shù),因?yàn)樵趯?shí)例化一個(gè)對(duì)象時(shí)才會(huì)調(diào)用構(gòu)造函數(shù),且虛函數(shù)的實(shí)現(xiàn),其實(shí)本質(zhì)是通過(guò)一個(gè)虛函數(shù)表指針來(lái)調(diào)用的,還沒(méi)有對(duì)象更沒(méi)有內(nèi)存空間當(dāng)然無(wú)法調(diào)用了,故沒(méi)有實(shí)例化一個(gè)對(duì)象之前的虛構(gòu)造函數(shù)沒(méi)有意義也不能實(shí)現(xiàn)。
但析構(gòu)函數(shù)卻是可以為虛函數(shù)的,且大多時(shí)候都聲明為虛析構(gòu)函數(shù)。這樣就可以在用基類的指針指向派生類的對(duì)象在釋放時(shí),可以根據(jù)實(shí)際所指向的對(duì)象類型動(dòng)態(tài)聯(lián)編調(diào)用子類的析構(gòu)函數(shù),實(shí)現(xiàn)正確的對(duì)象內(nèi)存釋放。
下面我們做一個(gè)實(shí)驗(yàn),請(qǐng)看代碼:
/************************************** //Des:C++教程demo //Author:Huang //Copyright:www.sztianhecheng.cn //Date:2017/12/27 **************************************/ #include <iostream> using namespace std; class Point { private: int x,y; int *str; public: Point(int x=0,int y=0) { this->x = x; this->y = y; str = new int[100]; } ~Point() { delete []str; cout<<"Called Point's Destructor and Deleted str!"<<endl; } }; class Circle:public Point { private: int r; int *str; public: Circle(int x,int y,int R):Point(x,y) { r = R; str = new int[100]; } ~Circle() { delete []str; cout<<"Called Circle's Destructor and Deleted str!"<<endl; } }; int main() { Point *p; p = new Circle(10,10,20); delete p; return 0; }
可以看到代碼,基類中沒(méi)有用virtual聲明的析構(gòu)函數(shù),且基類和派生類當(dāng)中都有動(dòng)態(tài)內(nèi)存開(kāi)辟,那么我們?cè)谥骱瘮?shù)中也動(dòng)態(tài)開(kāi)辟內(nèi)存的方式創(chuàng)建一個(gè)Circle類,然后刪除,之后運(yùn)行后截圖如下:
可以清楚的看到,僅僅調(diào)用了基類的析構(gòu)函數(shù),這樣一來(lái)派生類中new出來(lái)的4*100字節(jié)的內(nèi)存就會(huì)殘留,造成內(nèi)存泄漏!
而如果把基類中析構(gòu)函數(shù)聲明為virtual,則結(jié)果大有不同!這個(gè)時(shí)候多態(tài)效應(yīng)出現(xiàn),會(huì)先調(diào)用釋放派生類的空間,然后再釋放基類的內(nèi)存空間,完美結(jié)束,如下圖:
以上,這就是虛析構(gòu)函數(shù)帶來(lái)的好處,大家自行體會(huì)。
C語(yǔ)言網(wǎng)提供由在職研發(fā)工程師或ACM藍(lán)橋杯競(jìng)賽優(yōu)秀選手錄制的視頻教程,并配有習(xí)題和答疑,點(diǎn)擊了解:
一點(diǎn)編程也不會(huì)寫(xiě)的:零基礎(chǔ)C語(yǔ)言學(xué)練課程
解決困擾你多年的C語(yǔ)言疑難雜癥特性的C語(yǔ)言進(jìn)階課程
從零到寫(xiě)出一個(gè)爬蟲(chóng)的Python編程課程
只會(huì)語(yǔ)法寫(xiě)不出代碼?手把手帶你寫(xiě)100個(gè)編程真題的編程百練課程
信息學(xué)奧賽或C++選手的 必學(xué)C++課程
藍(lán)橋杯ACM、信息學(xué)奧賽的必學(xué)課程:算法競(jìng)賽課入門課程
手把手講解近五年真題的藍(lán)橋杯輔導(dǎo)課程