當我們在使用C++編程語言進行程序開發的時候,會逐漸的發現這一語言給我們的程序開發帶來了非常大的好處。我們知道,用C++開發的時候,用來做基類的類的C++虛構函數一般都是虛函數。可是,為什麼要這樣做呢?下面用一個小例子來說明:
有下面的兩個類:
- 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!
這個很簡單,非常好理解。
但是,如果把類ClxBase析構函數前的virtual去掉,那輸出結果就是下面的樣子了:
- Do something in class ClxDerived!
所以,文章開頭的那個問題的答案就是--這樣做是為了當用一個基類的指針刪除一個派生類的對象時,派生類的析構函數會被調用。
當然,並不是要把所有類的析構函數都寫成虛函數。因為當類裡面有虛函數的時候,編譯器會給類添加一個虛函數表,裡面來存放虛函數指針,這樣就會增加類的存儲空間。所以,只有當一個類被用來作為基類的時候,才把C++虛構函數寫成虛函數。