不能被繼承的類

2021-06-22 00:35:35 字數 978 閱讀 3374

不能被繼承的類,就是子類在呼叫父類的建構函式的時候失敗就沒法被整合了,所以可以把析構函式定義為private,因為在呼叫建構函式的時候,會先檢查析構函式,如果析構是private的,那麼建構函式也沒法被呼叫。

這個問題和另一篇文章類似我們通過設定共有的static函式來構造和析構。

class a  

~a(){}

public:

static a* create()

void destory()

};

這樣的類只能在堆上實現,也就是只能通過new出來,而不能在棧上實現。利用虛繼承,我們可以同時在堆上和棧上都可以實現這個類的例項。

template class makesealed

~makesealed() {}

};class sealedclass: virtual public makesealed

~sealedclass() {}

};

在這個sealedclass使用起來和一般的型別沒什麼區別,我們可以在棧上 ,堆上建立例項,儘管類makesealed的建構函式是private的,但是因為類sealedclass是它的友元類,因此在sealedclass中可以呼叫它的私有函式。

但是當我們試圖從sealedclass中繼承乙個類並建立它的例項的時候,卻不能編譯通過,例如:

class try: public sealedclass

~try() {}

};

由於sealedclass是虛繼承自makesealed的,在呼叫try時,不會呼叫sealedclass的建構函式,而是會跳過sealedclass去呼叫makesealed的建構函式,但是因為try不是makesealed的友元類,所以無法呼叫其建構函式。這樣就打到了題目的要求,prefect!

不能被繼承的類

題目 用c 設計乙個不能被繼承的類。分析 乙個類被繼承後,在生成派生類物件時,派生類會主動呼叫父類的建構函式,所以如果父類的建構函式被設定成私有時,派生類的物件就無法構建。一 直接將建構函式設為私有函式 class sealedclass static void deleteinstance sea...

不能被繼承的類

何如建立乙個不能被繼承的類呢?c 語法規定虛基類必須由子類顯示初始化。如果你不在初始化列表裡顯示呼叫虛基類的建構函式,則編譯器會呼叫預設建構函式 如果類沒有預設建構函式,則編譯不通過。利用這個特點,建立乙個private建構函式的類a,並讓類b成為他的友元類,讓類b虛繼承類a 此時類b就不能被繼承了...

不能被繼承的類

題目 用c 設計乙個不能被繼承的類。在c 中,子類的建構函式會自動呼叫父類的建構函式,子類的析構函式也會自動呼叫父類的析構函式。要想乙個類不能被繼承,我們只要把它的建構函式和析構函式都定義為私有函式。那麼當乙個類試圖從它那裡繼承的時候,必然會由於呼叫建構函式 析構函式而導致編譯錯誤。同時,我們可以通...