我們知道,用C++開(kāi)發(fā)的時(shí)候,用來(lái)做基類(lèi)的類(lèi)的析構函數一般都是虛函數??墒?,為什么要這樣做呢?下面用一個(gè)小例子來(lái)說(shuō)明:
有下面的兩個(gè)類(lèi):
class ClxBase
{
public:
ClxBase() {};
virtual ~ClxBase() {};
virtual void DoSomething() { cout << "Do something in class ClxBase!" << endl; };
};
class ClxDerived : public ClxBase
{
public:
ClxDerived() {};
~ClxDerived() { cout << "Output from the destructor of class ClxDerived!" << endl; };
void DoSomething() { cout << "Do something in class ClxDerived!" << endl; };
};
代碼
ClxBase *pTest = new ClxDerived;
pTest->DoSomething();
delete pTest;
的輸出結果是:
Do something in class ClxDerived!
Output from the destructor of class ClxDerived!
這個(gè)很簡(jiǎn)單,非常好理解。
但是,如果把類(lèi)ClxBase析構函數前的virtual去掉,那輸出結果就是下面的樣子了:
Do something in class ClxDerived!
也就是說(shuō),類(lèi)ClxDerived的析構函數根本沒(méi)有被調用!一般情況下類(lèi)的析構函數里面都是釋放內存資源,而析構函數不被調用的話(huà)就會(huì )造成內存泄漏。我想所有的C++程序員都知道這樣的危險性。當然,如果在析構函數中做了其他工作的話(huà),那你的所有努力也都是白費力氣。
所以,文章開(kāi)頭的那個(gè)問(wèn)題的答案就是--這樣做是為了當用一個(gè)基類(lèi)的指針刪除一個(gè)派生類(lèi)的對象時(shí),派生類(lèi)的析構函數會(huì )被調用。
當然,并不是要把所有類(lèi)的析構函數都寫(xiě)成虛函數。因為當類(lèi)里面有虛函數的時(shí)候,編譯器會(huì )給類(lèi)添加一個(gè)虛函數表,里面來(lái)存放虛函數指針,這樣就會(huì )增加類(lèi)的存儲空間。所以,只有當一個(gè)類(lèi)被用來(lái)作為基類(lèi)的時(shí)候,才把析構函數寫(xiě)成虛函數。
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請
點(diǎn)擊舉報。