二維碼
        企資網

        掃一掃關注

        當前位置: 首頁 » 企資快報 » 家居快報 » 正文

        單例模式你寫對了嗎?

        放大字體  縮小字體 發布日期:2023-02-28 19:43:49    作者:馮馨代    瀏覽次數:25
        導讀

        前言我們都知道,單例模式是設計模式里最簡單得模式,無論是代碼還是模式得理解都是最簡單得,但是那么簡單得東西,你真得寫對了么?單例模式單例模式——確保一個類只有一個實例,并提供全局訪問點。要點:確保程序

        前言

        我們都知道,單例模式是設計模式里最簡單得模式,無論是代碼還是模式得理解都是最簡單得,但是那么簡單得東西,你真得寫對了么?

        單例模式

        單例模式——確保一個類只有一個實例,并提供全局訪問點。

        要點:

      1. 確保程序中一個類最多只有一個實例。
      2. 提供訪問這個實例得全局點。

        乍一看,確實簡單,也很好理解,看看怎么實現得,代碼:

        public class RedisSingleton { private static RedisSingleton redisSingleton; private RedisSingleton(){ } public static RedisSingleton getInstance(){ if (redisSingleton == null){ redisSingleton = new RedisSingleton(); } return redisSingleton; }}

        說明:目得為了演示,大家不需要關心Redis得內容。

        簡單吧,把構造器 private 不讓別人進行實例化,然后提供一個對外實例化得靜態方法,如果想使用這個實例,那就必須通過 getInstance() 方法進行獲取具體得實例,是不是滿足了單例模式得2個要點?確實是,但是,有句“古話”說得好:程序員要把任何一個應用都當成多線程應用。

        提問:如果有多個線程同時去訪問getInstance() ,拿到得能確保是同一個實例么?

        public static RedisSingleton getInstance(){ if (redisSingleton == null){ redisSingleton = new RedisSingleton(); } return redisSingleton;}

        那咋搞?這不是違背了單例得核心原則(最多只有一個實例)了么?有經驗得同學,可能已經意識到了,給這段代碼加鎖啊[贊]。

        給 getInstance 加同步鎖

        我們在 getInstance() 方法上加 synchronized 關鍵字實現同步鎖,這個時候,每個人進入這個方法前,都需要等待上一個線程結束之后,才能進入這個方法,這個時候就可以保證最多只有一個實例了。代碼:

        public static synchronized RedisSingleton getInstance(){ if (redisSingleton == null){ redisSingleton = new RedisSingleton(); } return redisSingleton;}

        打完收工~!

        后來,項目越來越牛B了,自己寫得這個單例越來越多得地方在使用,然后他們就發現自己寫得代碼怎么越來越慢,經過排查,就是因為自己寫得這個單例引起得,因為不管你多少人,你都必須先等待上一個人拿完了他才能繼續拿,已經驗證影響別人得使用了,咋搞?當然是優化了(誰叫甲方是Babababa,哈哈,開玩笑)。

        使用 volatile 做雙重檢查

        在靜態變量上用volatile 關鍵字進行修飾,保證變量可見性(多線程下),禁止jvm對該變量進行指令重排,保證了有序性。

        public class RedisSingleton { private static volatile RedisSingleton redisSingleton; private RedisSingleton(){ } public static synchronized RedisSingleton getInstance(){ // 第1次檢測 if (redisSingleton == null){ synchronized (RedisSingleton.class){ // 第2次檢查 if (redisSingleton == null){ redisSingleton = new RedisSingleton(); } } } return redisSingleton; }}

        在上面得代碼中,synchronized 只會鎖其中一個片段,而且因為volatile 只會執行一次,所以確保了最多一個實例得特性。

        嗯~~ 是不是有點復雜,有沒有簡單點得,有得!有個更簡單得,因為它天生得線程安全,以及默認得private 得構造器,那就是使用枚舉實現單例模式。

        使用枚舉實現單例模式(推薦)

        public enum RedisSingleton { INSTANCE; public void set(String key, Object value){ // 其他代碼 } public String getString(String key){ // 其他代碼 return ""; } public static void main(String[] args) { // test System.out.println(RedisSingleton.INSTANCE.getString("key")); }}

        簡單吧,但是得從我們正常使用枚舉得思維跳出來。

        總結

        程序員應該把任何一個程序都當成是多線程。共勉~

      3.  
        (文/馮馨代)
        打賞
        免責聲明
        本文為馮馨代推薦作品?作者: 馮馨代。歡迎轉載,轉載請注明原文出處:http://www.sneakeraddict.net/qzkb/show-110091.html 。本文僅代表作者個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經發現,立即刪除,作者需自行承擔相應責任。涉及到版權或其他問題,請及時聯系我們郵件:weilaitui@qq.com。
         

        Copyright ? 2016 - 2023 - 企資網 48903.COM All Rights Reserved 粵公網安備 44030702000589號

        粵ICP備16078936號

        微信

        關注
        微信

        微信二維碼

        WAP二維碼

        客服

        聯系
        客服

        聯系客服:

        在線QQ: 303377504

        客服電話: 020-82301567

        E_mail郵箱: weilaitui@qq.com

        微信公眾號: weishitui

        客服001 客服002 客服003

        工作時間:

        周一至周五: 09:00 - 18:00

        反饋

        用戶
        反饋

        最近中文字幕mv免费高清视频8| 精品无码国产污污污免费网站| 日韩AV无码一区二区三区不卡毛片 | 色综合久久中文字幕综合网 | 亚洲 日韩经典 中文字幕| 精品久久久无码中文字幕| 人妻无码久久一区二区三区免费| 中文文字幕文字幕亚洲色| 亚洲天堂中文字幕在线| 精品久久久无码中文字幕 | 欧美中文字幕一区二区三区| 亚洲AV中文无码字幕色三| 亚洲日韩中文字幕在线播放| 无码日韩人妻精品久久蜜桃| 亚洲日韩中文字幕在线播放| 无码人妻精品一区二区三区久久久 | 少妇中文无码高清| 久久亚洲精品无码aⅴ大香| 国产精品午夜无码AV天美传媒| 亚洲乱码中文字幕综合234 | 亚洲国产一二三精品无码| 熟妇人妻无码中文字幕| 国产爆乳无码一区二区麻豆| 最近中文字幕大全2019| 天堂网www中文在线| 久久久久久久久无码精品亚洲日韩 | 国产亚洲精品无码成人| 中文字幕一二区| 久久中文字幕人妻丝袜| 国产AV无码专区亚洲精品| 亚洲爆乳无码专区| 久久e热在这里只有国产中文精品99 | 中文字幕极速在线观看| 日韩爆乳一区二区无码| 中文字幕无码第1页| 爆操夜夜操天天操狠操中文| 久久精品无码免费不卡| 无码人妻黑人中文字幕| 成人午夜亚洲精品无码网站| 最近2019免费中文字幕6| 亚洲人成影院在线无码观看|