{面试题2: 实现 Singleton 模式}
生活随笔
收集整理的這篇文章主要介紹了
{面试题2: 实现 Singleton 模式}
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
From 劍指Offer 何海濤 著
// 不好的解法一: 只適用于單線程環境 class Singleton1 {public:static Singleton1* getInstance(void) {if(instance == NULL) {instance = new Singleton1();}return instance;}private:static Singleton1 *instance;private:Singleton1(void) {}Singleton1(const Singleton1&);Singleton1& operator=(const Singleton1&);~Singleton1(void) {}class NestedClass {public:~NestedClass(void) {delete Singleton1::instance;Singleton1::instance = NULL;}};static NestedClass justForSingleton; // 實現程序結束時, 釋放 instance 占用的動態內存 }; // 不好的解法一(擴展): 只適用于單線程環境 class Singleton2 {public:static Singleton2& getInstance(void) {static Singleton2 instance; // 使用局部靜態變量, 實現 instance 占用內存的釋放return instance;}private:Singleton2(void) {}Singleton2(const Singleton2&);Singleton2& operator=(const Singleton2&);~Singleton2(void) {}}; // 可行的解法: 加同步鎖前后兩次判斷實例是否存在 pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; class Singleton1 {public:static Singleton1* getInstance(void) {if(instance == NULL) {pthread_mutex_lock(&mutex);if(instance == NULL) {instance = new Singleton1();}pthread_mutex_unlock(&mutex);}return instance;}private:static Singleton1 *instance;private:Singleton1(void) {}Singleton1(const Singleton1&);Singleton1& operator=(const Singleton1&);~Singleton1(void) {}class NestedClass {public:~NestedClass(void) {delete Singleton1::instance;Singleton1::instance = NULL;}};static NestedClass justForSingleton; };Singleton1* Singleton1::instance = NULL; // 強烈推薦的解法: 利用靜態成員變量 class Singleton3 {public:static Singleton3* getInstance(void) {return instance;}private:static Singleton3 *instance;private:Singleton3(void) {}Singleton3(const Singleton3&);Singleton3& operator=(const Singleton3&);~Singleton3(void) {}class NestedClass {public:~NestedClass(void) {delete Singleton3::instance;Singleton3::instance = NULL;}};static NestedClass justForSingleton; };Singleton3* Singleton3::instance = new Singleton3(); // 在程序開始時就會產生一個該類的實例,并在以后僅返回此實例 // 強烈推薦的的解法: 實現按需創建實例, 但這里并沒有實現(C++中實現按需創建, 似乎只能借助于鎖機制) class Singleton4 {public:static Singleton4* getInstance(void) {return &NestedClass::instance; // 實例在進入主程序前已完成初始化}private:Singleton4(void) {}Singleton4(const Singleton4&);Singleton4& operator=(const Singleton4&);~Singleton4(void) {}class NestedClass {public:static Singleton4 instance;}; }; Singleton4 Singleton4::NestedClass::instance;?
?
總結:
1.?程序在結束的時候,系統會自動析構所有的全局變量: 可以在類對象中添加一個靜態類對象, 實現該類中靜態變量占有的動態內存;
在單例類內部定義專有的嵌套類; 在單例類內定義私有的專門用于釋放的靜態成員; 利用程序在結束時析構全局變量的特性,選擇最終的釋放時機; 使用單例的代碼不需要任何操作,不必關心對象的釋放。2.?C++0X以后,要求編譯器保證內部靜態變量的線程安全性,可以不加鎖。但C++ 0X以前,仍需要加鎖, 實現線程安全性;
3.?靜態實例初始化在程序開始時進入主函數之前就由主線程以單線程方式完成了初始化,不必擔心多線程問題。
參考:
http://blog.csdn.net/hackbuteer1/article/details/7460019
http://www.cnblogs.com/ccdev/archive/2012/12/19/2825355.html
轉載于:https://www.cnblogs.com/long3216/p/4438819.html
總結
以上是生活随笔為你收集整理的{面试题2: 实现 Singleton 模式}的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JavaScript确认提交?
- 下一篇: UVa 11107 (后缀数组 二分)