日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

{面试题2: 实现 Singleton 模式}

發布時間:2025/7/14 编程问答 16 豆豆
生活随笔 收集整理的這篇文章主要介紹了 {面试题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 模式}的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。