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; };
};

    代碼web

ClxBase *pTest =  new ClxDerived;
pTest->DoSomething();
delete pTest;

    的輸出結果是:函數

Do something in class ClxDerived!
Output from the destructor of class ClxDerived!

    這個很簡單,很是好理解。
    可是,若是把類ClxBase析構函數前的virtual去掉,那輸出結果就是下面的樣子了:spa

Do something in class ClxDerived!

    也就是說,類ClxDerived的析構函數根本沒有被調用!通常狀況下類的析構函數裏面都是釋放內存資源,而析構函數不被調用的話就會形成內存泄漏。我想全部的C++程序員都知道這樣的危險性。固然,若是在析構函數中作了其餘工做的話,那你的全部努力也都是白費力氣。
    因此,文章開頭的那個問題的答案就是--這樣作是爲了當用一個基類的指針刪除一個派生類的對象時,派生類的析構函數會被調用。
    固然,並非要把全部類的析構函數都寫成虛函數。由於當類裏面有虛函數的時候,編譯器會給類添加一個虛函數表,裏面來存放虛函數指針,這樣就會增長類的存儲空間。因此,只有當一個類被用來做爲基類的時候,才把析構函數寫成虛函數。指針

相關文章
相關標籤/搜索