淺談JAVASE單例設計模式
簡單的說設計模式,其實就是對問題行之有效的解決方式。其實它是一種思想。
1.單例設計模式。
解決的問題:就是可以保證一個類在內(nèi)存中的對象唯一性。(單個實例)
使用單例設計模式需求:必須對于多個程序使用同一個配置信息對象時,就需要保證該對象的唯一性。
如何保證對象唯一性? 解決步驟:
1.不允許其他程序用new創(chuàng)建該對象。 1.私有化該類構(gòu)造函數(shù)。
2.在該類創(chuàng)建一個本類實例。 2.通過new 在該類中創(chuàng)建一個本類對象。
3.對外提供一個方法讓其他程序可以獲取該對象。 3.定義一個公有的方法,將創(chuàng)建的對象返回。
//餓漢式(開發(fā)時常用) class Single//類一加載,對象就已經(jīng)存在了。 { private static Single s = new Single(); private Single(){} public static Single getInstance() { return s; } }
//懶漢式(面試時常問,在多線程并發(fā)訪問時候有可能導致不能保證不了對象的唯一性,存在安全隱患?。? class Single2//類加載進來,沒有對象,只有調(diào)用了getInstance方法時,才會創(chuàng)建對象。 //延遲加載形式。 { private static Single2 s = null; private Single2(){} public static Single2 getInstance() { if(s==null) s = new Single2(); return s; } } //調(diào)用類 class SingleDemo { public static void main(String[] args) { Single s1 = Single.getInstance(); Single s2 = Single.getInstance(); System.out.println(s1==s2); // Single ss = Single.s; //此處不采用這個是因為不可控,采用 Single.getInstance();可以傳參數(shù)進行相應調(diào)用。 } }
餓漢式單例類在自己被加載時就將自己實例化。即便加載器是靜態(tài)的,在餓漢式單例類被加載時仍會將自己實例化。單從資源利用效率角度來講,這個比懶漢式單例類稍差些。從速度和反應時間角度來講,則比懶漢式單例類稍好些。
3.登記式:
代碼:
package pattern.singleton;import java.util.HashMap;import java.util.Map; //登記式單例類. //類似Spring里面的方法,將類名注冊,下次從里面直接獲取。 public class Singleton3 { private static Map<String,Singleton3> map = new HashMap<String,Singleton3>(); static{ Singleton3 single = new Singleton3(); map.put(single.getClass().getName(), single); } //保護的默認構(gòu)造子 protected Singleton3(){} //靜態(tài)工廠方法,返還此類惟一的實例 public static Singleton3 getInstance(String name) { if(name == null) { name = Singleton3.class.getName(); System.out.println("name == null"+"--->name="+name); } if(map.get(name) == null) { try { map.put(name, (Singleton3) Class.forName(name).newInstance()); } catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } } return map.get(name); } //一個示意性的商業(yè)方法 public String about() { return "Hello, I am RegSingleton."; } public static void main(String[] args) { Singleton3 single3 = Singleton3.getInstance(null); System.out.println(single3.about()); } }
相關(guān)文章
SpringBoot2.X Kotlin系列之數(shù)據(jù)校驗和異常處理詳解
這篇文章主要介紹了SpringBoot 2.X Kotlin系列之數(shù)據(jù)校驗和異常處理詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04Java 實戰(zhàn)項目之教材管理系統(tǒng)的實現(xiàn)流程
讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實現(xiàn)教材管理系統(tǒng),大家可以在過程中查缺補漏,提升水平2021-11-11Idea中如何查看SpringSecurity各Filter信息
這篇文章主要介紹了Idea中如何查看SpringSecurity各Filter信息,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01mybatis-plus 關(guān)于savebatch,saveorupdatebatch遇到的坑及解決辦法
本文主要介紹了mybatis-plus 關(guān)于savebatch,saveorupdatebatch遇到的坑及解決辦法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-01-01java多線程編程同步器Future和FutureTask解析及代碼示例
這篇文章主要介紹了java多線程編程同步器Future和FutureTask解析及代碼示例,對二者進行了詳細介紹,分析了future的源碼,最后展示了相關(guān)實例代碼,具有一定參考價值 ,需要的朋友可以了解下。2017-11-11SpringBoot結(jié)合Redis配置工具類實現(xiàn)動態(tài)切換庫
本文主要介紹了SpringBoot結(jié)合Redis配置工具類實現(xiàn)動態(tài)切換庫,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08Java實現(xiàn)添加、驗證PDF數(shù)字簽名的方法示例
在設置文檔內(nèi)容保護的方法中,除了對文檔加密、添加水印外,應用數(shù)字簽名也是一種有效防偽手段。本文就使用Java實現(xiàn)添加、驗證PDF數(shù)字簽名,感興趣的可以了解一下2021-07-07java字符串比較獲取字符串出現(xiàn)次數(shù)的示例
java獲取一個字符串在整個字符串出現(xiàn)的次數(shù),下面寫出我的思路和二個實現(xiàn)方法,大家參考使用吧2014-01-01