題目:
用c++設計乙個不能被繼承的類。
分析:
乙個類被繼承後,在生成派生類物件時,派生類會主動呼叫父類的建構函式,所以如果父類的建構函式被設定成私有時,派生類的物件就無法構建。
一、直接將建構函式設為私有函式
class sealedclass
static
void deleteinstance( sealedclass* pinstance )
private:
sealedclass() {}
~sealedclass() {}
};class test : public sealedclass
;int main( void )
2.虛擬繼承
template class makesealed
~makesealed() {}
};class sealedclass2 : virtual
public makesealed
~sealedclass2() {}
};class try : public sealedclass2
{};
不能被繼承的類
不能被繼承的類,就是子類在呼叫父類的建構函式的時候失敗就沒法被整合了,所以可以把析構函式定義為private,因為在呼叫建構函式的時候,會先檢查析構函式,如果析構是private的,那麼建構函式也沒法被呼叫。這個問題和另一篇文章類似我們通過設定共有的static函式來構造和析構。class a a ...
不能被繼承的類
何如建立乙個不能被繼承的類呢?c 語法規定虛基類必須由子類顯示初始化。如果你不在初始化列表裡顯示呼叫虛基類的建構函式,則編譯器會呼叫預設建構函式 如果類沒有預設建構函式,則編譯不通過。利用這個特點,建立乙個private建構函式的類a,並讓類b成為他的友元類,讓類b虛繼承類a 此時類b就不能被繼承了...
不能被繼承的類
題目 用c 設計乙個不能被繼承的類。在c 中,子類的建構函式會自動呼叫父類的建構函式,子類的析構函式也會自動呼叫父類的析構函式。要想乙個類不能被繼承,我們只要把它的建構函式和析構函式都定義為私有函式。那麼當乙個類試圖從它那裡繼承的時候,必然會由於呼叫建構函式 析構函式而導致編譯錯誤。同時,我們可以通...