用C++设计一个不能被继承的类
生活随笔
收集整理的這篇文章主要介紹了
用C++设计一个不能被继承的类
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
????? 在C#中定義了關鍵字sealed,被sealed修飾的類不能被繼承。在Java中同樣也有關鍵字final表示一個類型不能被繼承。在C++中沒有類似于sealed和final的關鍵字,所以我們只有自己來實現。
????? 很多人都能夠想到,類的構造函數和析構函數是關鍵。因為子類的構造函數會自動調用父類的構造函數。子類的析構函數也會自動調用父類的析構函數。所以要想使一個類不能被繼承,只有把它的構造函數和析構函數都定義為私有函數或保護函數,那么當一個類試圖從這個類繼承的時候,必然會先調用構造函數而產生編譯錯誤,從而導致繼承失敗。
????? 這個不能被繼承類的構造函數和析構函數都是私有函數,那么怎樣才能得到該類的實例呢? 這倒不難,可以通過定義公有的靜態函數來創建和釋放類的實例,實現該類不能被繼承但能被實例化的功能。
????? 基于這個思路,我們可以寫出如下代碼:
#include<iostream> using namespace std;class SealedClass { private: // 私有成員SealedClass() { }; // 構造函數~SealedClass() { }; // 析構函數 public:int m_number;static SealedClass* GetInstance(int number) // 用于構造的函數{SealedClass * pInstance = new SealedClass();pInstance->m_number = number;return pInstance;}static void DeleteInstance(SealedClass* pInstance) // 用于析構的函數{delete pInstance;pInstance = 0;} };int main(void) {SealedClass * p = SealedClass::GetInstance(9);cout<<"m_number is : "<<p->m_number<<endl;SealedClass::DeleteInstance(p);cout<<"m_number is : "<<p->m_number<<endl;return 0; } 輸出結果如下:
????? 很多人都能夠想到,類的構造函數和析構函數是關鍵。因為子類的構造函數會自動調用父類的構造函數。子類的析構函數也會自動調用父類的析構函數。所以要想使一個類不能被繼承,只有把它的構造函數和析構函數都定義為私有函數或保護函數,那么當一個類試圖從這個類繼承的時候,必然會先調用構造函數而產生編譯錯誤,從而導致繼承失敗。
????? 這個不能被繼承類的構造函數和析構函數都是私有函數,那么怎樣才能得到該類的實例呢? 這倒不難,可以通過定義公有的靜態函數來創建和釋放類的實例,實現該類不能被繼承但能被實例化的功能。
????? 基于這個思路,我們可以寫出如下代碼:
#include<iostream> using namespace std;class SealedClass { private: // 私有成員SealedClass() { }; // 構造函數~SealedClass() { }; // 析構函數 public:int m_number;static SealedClass* GetInstance(int number) // 用于構造的函數{SealedClass * pInstance = new SealedClass();pInstance->m_number = number;return pInstance;}static void DeleteInstance(SealedClass* pInstance) // 用于析構的函數{delete pInstance;pInstance = 0;} };int main(void) {SealedClass * p = SealedClass::GetInstance(9);cout<<"m_number is : "<<p->m_number<<endl;SealedClass::DeleteInstance(p);cout<<"m_number is : "<<p->m_number<<endl;return 0; } 輸出結果如下:
總結
以上是生活随笔為你收集整理的用C++设计一个不能被继承的类的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: const_cast的应用
- 下一篇: c语言面试精华版