1.第一段**
#include
using namespace std;
class clxbase;
~clxbase() ;
void dosomething() ;
};class clxderived : public clxbase;
~clxderived() ;
void dosomething() ;
}; int
main()
執行結果:
do something in class clxderived!
output from the destructor of class clxderived!
output from the destructor of class clxbase!
這段**中基類的析構函式不是虛函式,在main函式中用繼承類的指標去操作繼承類的成員,釋放指標p的過程是:先釋放繼承類的資源,再釋放基類資源.
2.第二段**
#include
using namespace std;
class clxbase;
~clxbase() ;
void dosomething() ;
};class clxderived : public clxbase;
~clxderived() ;
void dosomething()
}; int
main()
輸出結果:
do something in class clxbase!
output from the destructor of class clxbase!
這段**中基類的析構函式同樣不是虛函式,不同的是在main函式中用基類的指標去操作繼承類的成員,釋放指標p的過程是:只是釋放了基類的資源,而沒有呼叫繼承類的析構函式.呼叫dosomething()函式執行的也是基類定義的函式.
一般情況下,這樣的刪除只能夠刪除基類物件,而不能刪除子類物件,形成了刪除一半角象,造成記憶體洩漏.
在公有繼承中,基類對派生類及其物件的操作,只能影響到那些從基類繼承下來的成員.如果想要用基類對非繼承成員進行操作,則要把基類的這個函式定義為虛函式.
析構函式自然也應該如此:如果它想析構子類中的重新定義或新的成員及物件,當然也應該宣告為虛的.
3.第三段**:
#include
using namespace std;
class clxbase;
virtual ~clxbase() ;
virtual void dosomething() ;
};class clxderived : public clxbase;
~clxderived() ;
void dosomething() ;
};int
main()
執行結果:
do something in class clxderived!
output from the destructor of class clxderived!
output from the destructor of class clxbase!
這段**中基類的析構函式被定義為虛函式,在main函式中用基類的指標去操作繼承類的成員,釋放指標p的過程是:只是釋放了繼承類的資源,再呼叫基類的析構函式.呼叫dosomething()函式執行的也是繼承類定義的函式.
如果不需要基類對派生類及物件進行操作,則不能定義虛函式,因為這樣會增加記憶體開銷.當類裡面有定義虛函式的時候,編譯器會給類新增乙個虛函式表,裡面來存放虛函式指標,這樣就會增加類的儲存空間.所以,只有當乙個類被用來作為基類的時候,才把析構函式寫成虛函式.
什麼情況下,類的析構函式宣告為虛函式
include using namespace std class clxbase clxbase void dosomething class clxderived public clxbase clxderived void dosomething int main 執行結果 do someth...
析構函式在什麼情況下應該宣告為虛函式
如標題所言,乙個c 物件的析構函式,在什麼情況下,應該被宣告為乙個虛函式呢?看到這一標題,我興趣大增。首先,虛析構函式是什麼意思呢?well,你想想,乙個類的虛方法是什麼意思,就能明白虛析構函式是怎麼一回事兒了。如果乙個方法被宣告為虛方法,則當呼叫這個方法時,會呼叫具體實現此方法的物件方法,也稱動態...
析構函式一般在什麼情況下會被定義成虛函式?
今天去了kindsoft的筆試,關於c 有道題目大概是問 析構函式一般在什麼情況下會被定義成虛函式?1.首先看一下這段 吧 include using namespace std class clxbase clxbase void dosomething class clxderived publ...