解決父類無法釋放子類的堆區記憶體問題。
注意:純虛析構無法例項化
虛析構和純虛析構
多型使用時,如果子類有物件開闢到堆區,那麼父類指標在釋放時無法呼叫到子類的析構**
解決方式:將父類中的析構函式改為虛析構或者純虛析構
虛析構和純虛析構的共性:
可以解決父類指標釋放子類物件
都需要有具體的函式實現
虛析構和純虛析構的區別:
如果是純虛析構,該類屬於抽象類,無法例項化物件
#include
#include
#include
using
namespace std;
class
animal
//virtual ~animal()
// animal::
~animal()
virtual
void
speak()
=0;//純虛函式};
class
cat:
public animal
}virtual
void
speak()
string* m_name;};
void
test01()
intmain()
虛析構和純虛析構
多型使用時,如果子類有屬性開闢到堆區,那麼父類指標在釋放時無法帶呼叫到子類的析構 解決方式 將父類的析構函式改為純虛析構或者虛析構 1.可以解決父類指標釋放子類物件 2.都必須要有具體的函式實現 虛析構和純虛析構的區別 如果是純虛析構,該類屬於抽象類,無法例項化物件 include include ...
虛析構 純虛析構
析構函式的工作方式是 最底層的派生類 most derived class 的析構函式最先被呼叫,然後呼叫每乙個基類的析構函式。從高到低依次析構 因為在c 中,當乙個派生類物件通過使用乙個基類指標進行刪除 b a a a new b delete a 而這個基類有乙個非虛的析構函式,則結果是未定義的...
4 7 5 虛析構和純虛析構
多型使用時,如果子類中有屬性開闢到堆區,那麼父類指標在釋放時無法呼叫到子類的析構 解決方式 將父類中的析構函式改為虛析構或者純虛析構 virtual 類名 virtual 類名 0 include include include include using namespace std class a...