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