国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

一個單例還能寫出花來嗎?

開發 前端
單例可以說是最簡單的一個設計模式了,單例模式要求只能創建一個對象實例。通常的寫法是聲明私有的構造函數,提供靜態方法獲取單例的對象實例。

[[393262]]

 單例可以說是最簡單的一個設計模式了,單例模式要求只能創建一個對象實例。通常的寫法是聲明私有的構造函數,提供靜態方法獲取單例的對象實例。

常見的單例寫法就是餓漢式、懶漢式、雙重加鎖驗證、靜態內部類和枚舉的方式,寫法可能大家都知道,不過針對不同的寫法還是有可以繼續深挖一下的地方,讓我們從最簡單的幾種寫法開始回顧單例,不想看前面的話直接往后翻好了。

回顧幾種實現方式

餓漢式

餓漢式的寫法通常靜態成員變量已經是初始化好的,優點是可以不加鎖就獲取到對象實例,線程安全,主要的缺點在于不是延加載,稍微存在內存的浪費,因為如果初始化的邏輯較為復雜,比如存在網絡請求或者一些復雜的邏輯在內,就會產生內存的浪費。

懶漢式

懶漢式的寫法解決了餓漢式浪費內存的問題,在真正需要獲取實例對象的才去執行初始化。

通常一般來說可能會有兩種方式,第一種就是不加鎖的寫法,很顯然這樣是肯定不行的,正常的方式一般都是通過同步鎖的方式加鎖獲取實例對象。

但是這種實現方式在之前的JDK版本synchronized沒有鎖優化的情況每次獲取單例對象性能存在很大的問題,于是乎有了DCL的寫法。

雙重加鎖驗證DCL

于是為了解決懶漢式性能的問題,雙重加鎖驗證的寫法誕生了,先判斷一次空,真的為空再執行加鎖,然后再判斷一次。

這樣的話,只有在實例對象是空的情況才會去加鎖創建對象,性能問題得到了一定程度上的解決,也不會和餓漢一樣有內存浪費的問題。

但是,這個寫法也存在問題,就是會拿到未初始化完全的對象,我之前的一篇文章中也提到這個方式的問題,具體請看一次群聊引發的血案。

讓我這里復用一下我寫過的東西。

  1. 從CPU的角度來看,instance = new Instance()可以分為分為幾個步驟:
  2. 分配對象內存空間
  3. 執行構造方法,對象初始化

instance指向分配的內存地址

實際上,由于指令重排的問題,2、3的步驟可能會發生重排序,那么問題就發生了。

instance先被指向內存地址,然后再執行初始化,如果此時另外一個線程來訪問getInstance方法,就會拿到instance不是null,最后拿到的將是一個沒有被完全初始化的對象!

現在也有很多人說這個問題在高版本的JDK中已經解決了,但是我是沒發現有什么直接證據,如果你知道,請你告訴我。

靜態內部類

這個通過JVM來保證創建單例對象的線程安全和唯一性,是比較好的辦法。

Singleton類加載的時候,SingletonHolder不會加載,只有在調用getInstance方法的時候才會執行初始化,這樣既起到了懶加載的作用,同時又使用到了JVM類加載機制,保證了單例對象初始化的線程安全。

這種方式也是目前比較推薦的一種方式。

枚舉

通過枚舉來實現單例是Effective Java作者 Josh Bloch 提倡的方式,也是單例模式的最佳實現方式。

為了看清楚枚舉怎么實現單例模式的,我們來編譯一下枚舉生成的最終字節碼。

執行javac Singleton.java生成class文件,接著執行javap -p Singleton.class,得到如下內容:

為了看到更詳細的內容,我們執行 javap -c Singleton。

通過最終生成的字節碼,我們其實發現本質上枚舉的初始化通過static代碼塊來進行初始化。

考慮下類加載的幾個步驟,加載->驗證->準備->解析->初始化,最終初始化就是執行static代碼塊,而static代碼塊是絕對線程安全的,只能由JVM來調度,這樣保證了線程安全。

枚舉的實現方式好處還不止于此,除了一目了然的實現簡單之外,還能防止其他幾種實現方式避免不了的幾個問題。

再說幾種方式的問題

反射破壞單例

除了枚舉之外,其他的幾種方式都可以通過反射的方式達到破壞單例的目的,就隨便以一個實現方式來舉例,這里最終的輸出結果是false。

如果拿去嘗試反射創建枚舉對象的話,則是會報錯,可以自己動手嘗試一下。

為什么會報錯,可以直接看一下newInstance的源碼,有一段特殊的關于枚舉類型的判斷,下圖中我紅色標記的部分。

序列化

除了眾所周知的使用反射來破壞單例之外,還有另外一種能破壞單例的方式就是序列化。

對上面的餓漢方法實現序列化,然后得到的結果是false,序列化前后對象發生了改變。

其實關鍵的部分在于ois.readObject方法,一路跟蹤最后找到一段代碼如下:

所以很明顯我們發現了最終實際上這里通過反射創建了一個新的對象,isInstantiable實際代表的應該是類或者屬性是序列化的,那么久就返回true,我們這里肯定是true,所以最終產生了一個新的對象。

枚舉為啥可以防止這個問題?枚舉的實現方式不太一樣而已,同樣跟蹤到枚舉部分的實現邏輯。

下圖中紅框標注的部分就是枚舉類型去實現反序列化的邏輯,最終只是通過valueOf方法查找枚舉,不存在新建一個對象的邏輯。

那么,怎么防止其他方式序列化對單例的破壞?再往下看看源碼,紅框標注的意思只要有readResolve方法就可以解決問題了。

實際上,最終解決方案也很簡單,單例類加上方法即可。

好了,打完收工。現在是北京時間4月15日凌晨1點整,困了,睡覺。

 

責任編輯:武曉燕 來源: 艾小仙
相關推薦

2024-02-22 10:02:03

單例模式系統代碼

2024-02-04 16:14:38

線程開發

2025-06-26 00:40:13

2022-06-27 19:19:26

算法題青蛙跳臺階

2022-09-29 08:39:37

架構

2021-10-11 08:08:02

Python異常程序

2020-06-02 09:22:45

腳本CPUDDG

2023-04-12 08:16:35

2025-02-07 09:34:12

2017-09-18 09:03:36

線程安全單例

2018-04-20 14:35:18

電費電腦收益

2021-08-04 12:26:00

Postman工具頻率

2022-05-30 08:02:51

事務日志MySQL數據庫

2010-08-16 10:10:22

SQL腳本

2017-09-18 09:17:07

線程安全單例

2022-02-21 08:00:23

開發代碼程序員

2024-05-16 12:03:54

Python代碼開發

2023-04-10 08:11:23

@Lazy懶漢模式餓漢模式

2021-09-07 10:44:35

異步單例模式

2023-10-08 10:14:12

點贊
收藏

51CTO技術棧公眾號

黄色小网站91| 激情综合在线观看| 日韩一区二区三区精品 | 欧美xxxx14xxxxx性爽| 成年人视频免费在线观看| 久久久久久久久免费| 国产欧美一区二区三区不卡高清| 中文无码日韩欧| 亚洲成av人片在线观看香蕉| 中国一级特黄毛片大片| 亚洲深深色噜噜狠狠爱网站| 欧美成人午夜免费视在线看片| 大片免费在线观看| 舔着乳尖日韩一区| 午夜两性免费视频| 韩国理伦片一区二区三区在线播放| 日本久久久久久久久久久| 成人影院av| 欧美一区二区三区在| 在线观看导航| 亚洲欧美一区二区久久| 1024av视频| 精品亚洲aⅴ乱码一区二区三区| 91视频最新| 欧洲杯什么时候开赛| 国产做受高潮69| 成人国产精品| 精品第一国产综合精品aⅴ| 国产三区视频在线观看| 欧美日韩另类国产亚洲欧美一级| 天堂中文av| 中文字幕一区二区三区蜜月| 国产成人无码精品久久久性色| 精品一二线国产| 一卡二卡3卡四卡高清精品视频| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美大片在线影院| 国产精品麻豆成人av电影艾秋| 精品国产1区二区| 男人天堂手机在线| 在线免费视频一区二区| 中文字幕视频在线免费| 亚洲精品免费在线播放| siro系绝美精品系列| 国产精品免费网站在线观看| 999sesese| 国产精品福利在线播放| 成人淫片免费视频95视频| 国产精品萝li| 美女黄a一级视频| 精品久久久久国产| 国产三级在线看| 色婷婷一区二区| 免费观看成人高潮| 日韩av有码在线| 男人天堂久久| 国模精品一区二区三区色天香| 亚洲精品aⅴ| 国产精品极品美女粉嫩高清在线| 国产精品久久久久一区二区三区厕所| 91精品中国老女人| 亚洲久久视频| 蜜桃网站在线观看| 国产欧美日产一区| 日韩写真在线| 欧美夫妻性生活| 都市激情国产精品| 欧美成人第一页| 欧美禁忌电影| 久久福利电影| 波多野结衣中文字幕一区| 1069男同网址| 精品久久一区二区| 四虎5151久久欧美毛片| 日韩中文字幕一区| 亚洲欧美在线视频| 成人在线黄色电影| 国产精品福利在线观看网址| 日韩高清不卡在线| 嫩草嫩草嫩草嫩草| 亚洲欧洲日产国码av系列天堂| 国产成人一区| 真实国产乱子伦对白视频| 午夜精品在线看| 欧美在线se| 久久亚裔精品欧美| 亚洲综合色噜噜狠狠| 国产日韩另类视频一区| 国产精品99久久久久久久| 久久精品综合网| www欧美xxxx| 91久久精品国产91久久| 久久蜜臀中文字幕| 九色porny自拍视频在线观看| 国产精品一区二区久久久| 粉嫩高潮美女一区二区三区| 成年网站在线| 国产精品久久久久99| 99re6这里只有精品视频在线观看| 国产二区在线播放| 日本道色综合久久影院| a亚洲天堂av| 欧美gv在线| 久热这里只精品99re8久| 一区二区三区精品视频| 亚洲91网站| 日本手机在线视频| 亚洲成人在线网| 在线午夜精品| 国产一级在线| 成人妇女免费播放久久久| 一区二区中文字幕在线| 国产午夜精品一区在线观看| 欧洲xxxxx| 亚洲精品wwwww| 老**午夜毛片一区二区三区 | 久久久久久伊人| 国产高清一区日本| 在线观看中文字幕的网站| 国产成人一区二区三区免费看| 亚洲精品五月天| 国产精品tv| 大香煮伊手机一区| 色噜噜狠狠狠综合曰曰曰| 国产一区999| 不卡一二三区| 国产免费色视频| 亚洲精品乱码久久久久久金桔影视| 亚洲综合国产激情另类一区| 一级在线观看| 国产精品丝袜久久久久久高清| 亚洲视频香蕉人妖| 日韩精品福利一区二区三区| www欧美激情| 午夜精品在线观看| 国产精品久久久久久久久免费相片 | 99视频精品免费| 欧美另类极品videosbest最新版本 | 免费av网址在线| 久久手机精品视频| 久久久久成人黄色影片| 精品视频一二| 性刺激的欧美三级视频| 久久人人97超碰精品888| 国产精品久久免费看| 亚州精品视频| 性欧美孕妇孕交| 91亚洲精品久久久久久久久久久久| 日本道精品一区二区三区| 99精品福利视频| 国产美女精品写真福利视频| 国产精品12p| 欧美肥老妇视频| 亚洲影视在线观看| 欧美日本三区| 亚洲按摩av| 免费看国产曰批40分钟| 久久久久久中文字幕| 亚洲电影第三页| 米奇777在线欧美播放| 国产 日韩 欧美一区| 黄色成人免费观看| 国产精品一区二区三区免费视频 | 欧美日韩专区| av资源一区| 国产精品亚洲二区在线观看| 日本成人黄色片| 777奇米四色成人影色区| 国产乱人伦偷精品视频不卡| 国产成人一二片| www视频在线观看免费| 自拍偷拍99| 欧美激情视频一区二区三区不卡| 亚洲最大成人网4388xx| 一区二区三区福利| 亚洲国产精选| 青青草观看免费视频在线 | 男人舔女人下面高潮视频| 国产精品视频在线播放| 日韩一区二区视频| av激情亚洲男人天堂| 激情综合网五月| 俺来也官网欧美久久精品| 国产精品天天av精麻传媒| 国产伦视频一区二区三区| 久久精品国产电影| 欧美日韩中文字幕在线视频| 国产麻豆欧美日韩一区| 欧美丝袜激情| 国产伦精品一区二区三区视频金莲| 4kfree性满足欧美hd18| 欧美日韩一区二区视频在线观看| 欧美精品久久一区二区| 日韩三区在线观看| 亚洲丝袜制服诱惑| 久久成人免费网| 日韩成人精品一区二区| 97久久网站| 国产精品久久久久久福利| 成年人免费看的视频|