多个if用什么设计模式_抽丝剥茧——单例设计模式
生活随笔
收集整理的這篇文章主要介紹了
多个if用什么设计模式_抽丝剥茧——单例设计模式
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
單例設計模式
兄弟們好,今天是最后一個設計模式了,也是我們最熟悉的單例設計模式,可以說這個設計模式是我們最先接觸到的設計模式了。想當年學習JavaSE的時候,老師聊到一個「餓漢式和懶漢式」,我還糾結了半天,這名字起的很完美。接下來我們一起復習一下單例設計模式吧。
定義:該類的實例僅僅存在一個。單個實例對象——單例模式
我們直接上代碼
1. 懶漢式
public class Single {private static final SingleDesgin singleDesgin = new SingleDesgin();private Single(){}public SingleDesgin newInstance(){return singleDesgin ;} }- 直接在類加載的時候創建對象,由虛擬機保證該對象僅僅被創建一次。(「推薦使用」)
2. 懶漢式
public class Single {private SingleDesgin singleDesgin ;private Single(){}public SingleDesgin newInstance(){if(singleDesgin == null){singleDesgin = new SingleDesgin();}return singleDesgin ;} }- 在多線程情況下可能會出現多個對象被常見,線程不安全。(「不推薦使用」)
3. 靜態內部類
public class Single {private Single(){}public SingleDesgin newInstance(){return SingleBuild.singleDesgin;}private static class SingleBuild{static SingleDesgin singleDesgin = new SingleDesgin();}}- 和懶漢式相同,由虛擬機保證對象線程安全。與之不同的是把類加載時機交給了開發者(「調用方法的時候」)
4. DCL單例
public class Single {private volatile SingleDesgin singleDesgin ;public SingleDesgin newInstance(){if(singleDesgin == null){synchronized (Single.class){if(singleDesgin == null){singleDesgin = new SingleDesgin();}}}return singleDesgin ;}}- 雙重加鎖,保證多線程安全,通過volatile保證線程可見性和有序性。
關于volatile關鍵字可以參考我之前的文章,不過過幾天我會發一篇完整講述JMM模型的文章,其中講到了volatile,可以「關注一波公眾號」。(打個廣告,哈哈哈)
5. 枚舉實現
public enum Single {INSTANCE }- 就這,就這。這個操作來自于Java創始人的寫法,牛批
- 優點:線程安全,肯定加載一次;防止序列化
- 缺點:將一個類搞成了枚舉,不容易區分
好啦,以上就是所有我認為比較典型的單例設計模式的類型了,至于說什么八種設計模式的寫法,無非也就是加一個靜態代碼塊等等操作,將一個操作分兩步執行了,沒什么新鮮的,上面五種比較典型,兄弟們可以盡情享用。設計模式要結束了。明天或者后天會發一篇文章做一個總結,并且計劃一下接下來要做的事情,明天晚上團建,看晚上回來的時間吧。
好啦,兄弟們晚安吶。明天又是元氣滿滿的一天呢。
總結
以上是生活随笔為你收集整理的多个if用什么设计模式_抽丝剥茧——单例设计模式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python如何判断列表是否为空_Pyt
- 下一篇: JavaSE——XML与JSON(语法格