資源描述:
《java常用的設(shè)計(jì)模式-單例模式的幾種實(shí)現(xiàn)方法》由會員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫。
1、classEagerSingleton{privatestaticfinalEagerSingletonm_instance=newEagerSingleton();/***私有的默認(rèn)構(gòu)造子*/privateEagerSingleton(){}/****靜態(tài)工廠方法*/publicstaticEagerSingletongetInstance(){returnm_instance;}}classEagerSingleton{privatestaticfinalEagerSingletonm_instance=newEagerSin
2、gleton();/***私有的默認(rèn)構(gòu)造子*/privateEagerSingleton(){}/****靜態(tài)工廠方法*/publicstaticEagerSingletongetInstance(){returnm_instance;}}/******************************懶漢式單例類.在第一次調(diào)用的時(shí)候?qū)嵗?*****************************/classLazySingleton{//注意,這里沒有finalprivatestaticLazySingletonm_instan
3、ce=null;/***私有的默認(rèn)構(gòu)造子*/privateLazySingleton(){}/****靜態(tài)工廠方法*/publicsynchronizedtaticLazySingletongetInstance(){if(m_instance==null){m_instance=newLazySingleton();}returnm_instance;}}classLazySingleton{//注意,這里沒有finalprivatestaticLazySingletonm_instance=null;/***私有的默認(rèn)構(gòu)造子*
4、/privateLazySingleton(){}/****靜態(tài)工廠方法*/publicsynchronizedtaticLazySingletongetInstance(){if(m_instance==null){m_instance=newLazySingleton();}returnm_instance;}}在上面給出懶漢式單例類實(shí)現(xiàn)里對靜態(tài)工廠方法使用了同步化,以處理多線程環(huán)境。有些設(shè)計(jì)師在這里建議使用所謂的"雙重檢查成例".必須指出的是,"雙重檢查成例"不可以在Java語言中使用。不十分熟悉的讀者,可以看看后面給出的小
5、節(jié)?! ⊥瑯?,由于構(gòu)造子是私有的,因此,此類不能被繼承。餓漢式單例類在自己被加載時(shí)就將自己實(shí)例化。即便加載器是靜態(tài)的,在餓漢式單例類被加載時(shí)仍會將自己實(shí)例化。單從資源利用效率角度來講,這個(gè)比懶漢式單例類稍差些?! 乃俣群头磻?yīng)時(shí)間角度來講,則比懶漢式單例類稍好些。然而,懶漢式單例類在實(shí)例化時(shí),必須處理好在多個(gè)線程同時(shí)首次引用此類時(shí)的訪問限制問題,特別是當(dāng)單例類作為資源控制器,在實(shí)例化時(shí)必然涉及資源初始化,而資源初始化很有可能耗費(fèi)時(shí)間。這意味著出現(xiàn)多線程同時(shí)首次引用此類的機(jī)率變得較大?! ○I漢式單例類可以在Java語言內(nèi)實(shí)現(xiàn),但不易
6、在C++內(nèi)實(shí)現(xiàn),因?yàn)殪o態(tài)初始化在C++里沒有固定的順序,因而靜態(tài)的m_instance變量的初始化與類的加載順序沒有保證,可能會出問題。這就是為什么GoF在提出單例類的概念時(shí),舉的例子是懶漢式的。他們的書影響之大,以致Java語言中單例類的例子也大多是懶漢式的。實(shí)際上,本書認(rèn)為餓漢式單例類更符合Java語言本身的特點(diǎn)。/***********************登記式單例類.類似Spring里面的方法,將類名注冊,下次從里面直接獲取********************/importjava.util.HashMap;cla
7、ssRegSingleton{staticprivateHashMapm_registry=newHashMap();static{RegSingletonx=newRegSingleton();m_registry.put(x.getClass().getName(),x);}/***保護(hù)的默認(rèn)構(gòu)造子*/protectedRegSingleton(){}/***靜態(tài)工廠方法,返還此類惟一的實(shí)例*/staticpublicRegSingletongetInstance(Stringname){if(name==null){name
8、=RegSingleton.class.getName();}if(m_registry.get(name)==null){try{m_registry.put(name,Class.forName(name).newInstance());}ca