设计模式_单实体模式
Singleton 三要素:private 構(gòu)造函數(shù)、 public 靜態(tài)方法、 public 靜態(tài)變量
單實(shí)例模式的三種線程安全實(shí)現(xiàn)方式(C++)
1 懶漢模式:即第一次調(diào)用該類實(shí)例的時(shí)候才產(chǎn)生一個(gè)新的該類實(shí)例,并在以后僅返回此實(shí)例。
需要用鎖,來保證其線程安全性:原因:多個(gè)線程可能進(jìn)入判斷是否已經(jīng)存在實(shí)例的if語句,從而non thread safety.
使用double-check來保證thread safety.但是如果處理大量數(shù)據(jù)時(shí),該鎖才成為嚴(yán)重的性能瓶頸。
class Singleton {private :static Singleton * m_instance;Singleton(){}public :static Singleton *getInstance(); }; Singleleton * Singleton::getInstance() {if(NULL == m_instance){Lock();//借用其他類來實(shí)現(xiàn),如boostif(NULL == m_instance){m_instacne = new Singleton();}UnLock();}return m_instance;}2 內(nèi)部靜態(tài)實(shí)例的懶漢模式
這里需要注意的是,C++0X以后,要求編譯器保證內(nèi)部靜態(tài)變量的線程安全性,可以不加鎖。但C++ 0X以前,仍需要加鎖。
class Singleton {private ://static Singleton * m_instance; Singleton(){}public :static Singleton *getInstance(){Lock();static Singleton instance;UnLock();return instance;} };3 餓漢模式:即無論是否調(diào)用該類的實(shí)例,在程序開始時(shí)就會(huì)產(chǎn)生一個(gè)該類的實(shí)例,并在以后僅返回此實(shí)例。(個(gè)人比較喜歡此方法)
由靜態(tài)初始化實(shí)例保證其線程安全性,WHY?因?yàn)殪o態(tài)實(shí)例初始化在程序開始時(shí)進(jìn)入主函數(shù)之前就由主線程以單線程方式完成了初始化,不必?fù)?dān)心多線程問題。
故在性能需求較高時(shí),應(yīng)使用這種模式,避免頻繁的鎖爭奪。
class Singleton {private :static const Singleton * m_instance;Singleton(){}public :static Singleton *getInstance(){return m_instance;} }; const Singleton * Singleton::m_instance = new Singleton();reference :http://www.cnblogs.com/ccdev/archive/2012/12/19/2825355.html
轉(zhuǎn)載于:https://www.cnblogs.com/graph/p/3224449.html
總結(jié)
以上是生活随笔為你收集整理的设计模式_单实体模式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 转载:Apache commons开源工
- 下一篇: Asp.Net微信发布菜单,出现“inv