精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

有關(guān)雙檢測(cè)鎖定(DCL)和Singleton模式的問(wèn)題

開(kāi)發(fā) 后端
本文解釋了一個(gè)有關(guān)雙檢測(cè)鎖定(DCL)和Singleton模式的問(wèn)題。在多線程的情況下Singleton模式會(huì)遇到不少問(wèn)題,一個(gè)解決方案是雙檢測(cè)鎖定,不過(guò)事實(shí)上這種方法在JDK5之前會(huì)導(dǎo)致問(wèn)題。

看OOP教材時(shí),提到了一個(gè)雙檢測(cè)鎖定(Double-Checked Lock, DCL)的問(wèn)題,但是書(shū)上沒(méi)有多介紹,只是說(shuō)這是一個(gè)和底層內(nèi)存機(jī)制有關(guān)的漏洞。查閱了下相關(guān)資料,對(duì)這個(gè)問(wèn)題大致有了點(diǎn)了解。

從頭開(kāi)始說(shuō)吧。

在多線程的情況下Singleton模式會(huì)遇到不少問(wèn)題,一個(gè)簡(jiǎn)單的例子

1:  class Singleton {      
   2:      private static Singleton instance = null;     
   3:        
   4:      public static Singleton instance() {     
   5:          if (instance == null) {     
   6:              instance = new Singleton();     
   7:          }     
   8:          return instance;    
   9:      }    
   10:  }
  

假設(shè)這樣一個(gè)場(chǎng)景,有兩個(gè)線程調(diào)用Singleton.instance(),首先線程一判斷instance是否等于null,判斷完后一瞬間虛擬機(jī)把線程二調(diào)度為運(yùn)行線程,線程二再次判斷instance是否為null,然后創(chuàng)建一個(gè)Singleton實(shí)例,線程二的時(shí)間片用完后,線程一被喚醒,接下來(lái)它執(zhí)行的代碼依然是instance = new Singleton();
兩次調(diào)用返回了不同的對(duì)象,出現(xiàn)問(wèn)題了。

最簡(jiǎn)單的方法自然是在類被載入時(shí)就初始化這個(gè)對(duì)象:private static Singleton instance = new Singleton();

JLS(Java Language Specification)中規(guī)定了一個(gè)類只會(huì)被初始化一次,所以這樣做肯定是沒(méi)問(wèn)題的。

但是如果要實(shí)現(xiàn)延遲初始化(Lazy initialization),比如這個(gè)實(shí)例初始化時(shí)的參數(shù)要在運(yùn)行期才能確定,應(yīng)該怎么做呢?

依然有最簡(jiǎn)單的方法:使用synchronized關(guān)鍵字修飾初始化方法:

  1. public synchronized static Singleton instance() {          
  2.     if (instance == null) {  
  3.         instance = new Singleton();  
  4.     }  
  5.     return instance;  
  6. }   

這里有一個(gè)性能問(wèn)題:多個(gè)線程同時(shí)訪問(wèn)這個(gè)方法時(shí),會(huì)因?yàn)橥蕉鴮?dǎo)致每次只有一個(gè)線程運(yùn)行,影響程序性能。而事實(shí)上初始化完畢后只需要簡(jiǎn)單的返回instance的引用就行了。

雙檢測(cè)鎖定解決方案

DCL是一個(gè)“看似”有效的解決方法,先把對(duì)應(yīng)代碼放上來(lái)吧:

    1 :   class Singleton {   
    2 :       private static Singleton instance = null ;   
    3 :      
    4 :       public static Singleton instance() {   
    5 :           if (instance == null ) {
    6 :               synchronized (this) {   
    7 :                   if (instance == null)
    8 :                      instance = new Singleton();
    9 :              }
    10 :          }
    11 :          return instance;
    12 :      }
    13 :  }

用JavaWorld上對(duì)應(yīng)文章的標(biāo)題來(lái)評(píng)論這種做法就是smart, but broken。來(lái)看原因:

Java編譯器為了提高程序性能會(huì)進(jìn)行指令調(diào)度,CPU在執(zhí)行指令時(shí)同樣出于性能會(huì)亂序執(zhí)行(至少現(xiàn)在用的大多數(shù)通用處理器都是out-of-order的),另外cache的存在也會(huì)改變數(shù)據(jù)回寫(xiě)內(nèi)存時(shí)的順序[2]。JMM(Java Memory Model, 見(jiàn)[1])指出所有的這些優(yōu)化都是允許的,只要運(yùn)行結(jié)果和嚴(yán)格按順序執(zhí)行所得的結(jié)果一樣即可。

Java假設(shè)每個(gè)線程都跑在自己的處理器上,享有自己的內(nèi)存,和共享的主存交互。注意即使在單核上這種模型也是有意義的,考慮到cache和寄存器會(huì)保存部分臨時(shí)變量。理論上每個(gè)線程修改自己的內(nèi)存后,必須立即更新對(duì)應(yīng)的主存內(nèi)容。但是Java設(shè)計(jì)師們認(rèn)為這種約束會(huì)影響程序性能,他們?cè)囍鴦?chuàng)造了一套讓程序跑得更快、但又保證線程之間的交互與預(yù)期一致的內(nèi)存模型。

synchronized關(guān)鍵字便是其中一把利器。事實(shí)上,synchronized塊的實(shí)現(xiàn)和Linux中的信號(hào)量(semaphore)還是有區(qū)別的,前者過(guò)程中鎖的獲得和釋放都會(huì)都會(huì)引發(fā)一次Memory Barrier來(lái)強(qiáng)制線程本地內(nèi)存和主存之間的同步。通過(guò)這個(gè)機(jī)制,Java中的同步機(jī)制保證了synchronized塊中指令的原子性(atomic)。

雙檢測(cè)鎖定的問(wèn)題

好了,回過(guò)頭來(lái)看DCL問(wèn)題。看起來(lái)訪問(wèn)一個(gè)未同步的instance字段不會(huì)產(chǎn)生什么問(wèn)題,我們?cè)俅蝸?lái)假設(shè)一個(gè)場(chǎng)景:

線程一進(jìn)入同步塊,執(zhí)行instance = new Singleton(); 線程二剛開(kāi)始執(zhí)行g(shù)etResource();

按照順序的話,接下來(lái)應(yīng)該執(zhí)行的步驟是 1) 分配新的Singleton對(duì)象的內(nèi)存 2) 調(diào)用Singleton的構(gòu)造器,初始化成員字段 3) instance被賦為指向新的對(duì)象的引用。

前面說(shuō)過(guò),編譯器或處理器都為了提高性能都有可能進(jìn)行指令的亂序執(zhí)行,線程一的真正執(zhí)行步驟可能是1) 分配內(nèi)存 2) instance指向新對(duì)象 3) 初始化新實(shí)例。如果線程二在2完成后3執(zhí)行前被喚醒,它看到了一個(gè)不為null的instance,跳出方法體走了,帶著一個(gè)還沒(méi)初始化的Singleton對(duì)象。

錯(cuò)誤發(fā)生的一種情形就是這樣,關(guān)于更詳細(xì)的編譯器指令調(diào)度導(dǎo)致的問(wèn)題,可以參看這個(gè)網(wǎng)頁(yè) [4]。

[3] 中提供了一個(gè)編譯器指令調(diào)度的證據(jù)

instance = new Singleton(); 這條命令在Symantec JIT中被編譯成

  1. 0206106A   mov         eax,0F97E78h  
  2. 0206106F   call        01F6B210                  ; 分配空間  
  3. 02061074   mov         dword ptr [ebp],eax       ; EBP中保存了instance的地址   
  4.  
  5. 02061077   mov         ecx,dword ptr [eax]       ; 解引用,獲得新的指針地址   
  6.  
  7. 02061079   mov         dword ptr [ecx],100h      ; 接下來(lái)四行是inline后的構(gòu)造器  
  8. 0206107F   mov         dword ptr [ecx+4],200h      
  9. 02061086   mov         dword ptr [ecx+8],400h  
  10. 0206108D   mov         dword ptr [ecx+0Ch],0F84030h   
  11.  

可以看到,賦值完成在初始化之前,而這是JLS允許的。
 
另一種情形是,假設(shè)線程一安穩(wěn)地完成Singleton對(duì)象的初始化,退出了同步塊,并同步了和本地內(nèi)存和主存。線程二來(lái)了,看到一個(gè)非空的引用,拿走。注意線程二沒(méi)有執(zhí)行一個(gè)Read Barrier,因?yàn)樗揪蜎](méi)進(jìn)后面的同步塊。所以很有可能此時(shí)它看到的數(shù)據(jù)是陳舊的。

還有很多人根據(jù)已知的幾種提出了一個(gè)又一個(gè)fix的方法,但最終還是出現(xiàn)了更多的問(wèn)題。可以參閱[3]中的介紹。

[5]中還說(shuō)明了即使把instance字段聲明為volatile還是無(wú)法避免錯(cuò)誤的原因。

由此可見(jiàn),安全的Singleton的構(gòu)造一般只有兩種方法,一是在類載入時(shí)就創(chuàng)建該實(shí)例,二是使用性能較差的synchronized方法。

本文來(lái)自ZelluX的BlogJava博客《Singleton模式與雙檢測(cè)鎖定(DCL) 》一文

參考資料:
[1] Java Language Specification, Second Edition, 第17章介紹了Java中線程和內(nèi)存交互關(guān)系的具體細(xì)節(jié)。
[2] out-of-order與cache的介紹可以參閱Computer System, A Programmer's Perspective的第四、五章。
[3] The "Double-Checked Locking is Broken" Declaration
[4] Synchronization and the Java Memory Model
[5] Double-checked locking: Clever, but broken
[6] Holub on Patterns, Learning Design Patterns by Looking at Code

【編輯推薦】

  1. 最簡(jiǎn)單的設(shè)計(jì)模式學(xué)習(xí):Singleton模式
  2. 詳解Java Singleton模式的好處
  3. Java設(shè)計(jì)模式與應(yīng)用淺談
  4. 設(shè)計(jì)模式在EJB中的應(yīng)用
  5. 探討JSF框架中使用的設(shè)計(jì)模式
責(zé)任編輯:yangsai 來(lái)源: ZelluX的博客
相關(guān)推薦

2025-06-10 09:07:32

Go模式開(kāi)發(fā)

2013-04-19 09:16:56

2009-07-08 17:25:05

Java Single

2009-07-09 17:30:59

Singleton模式C++ SingletJava Single

2010-02-06 10:04:10

Android啟動(dòng)模式

2009-08-31 16:12:02

C#使用Singlet

2009-08-25 18:04:30

C#實(shí)現(xiàn)Singlet

2009-09-02 16:23:27

C# Singleto

2009-08-31 15:48:02

C# Singleto

2012-08-22 10:10:25

單態(tài)單態(tài)設(shè)計(jì)設(shè)計(jì)模式

2011-07-18 16:51:51

Cocoa 單態(tài) 模式

2010-07-14 14:20:47

IMAP協(xié)議服務(wù)

2009-08-12 13:22:44

Singleton模式

2009-09-24 16:55:27

策略模式

2021-03-18 18:07:57

JavaScript開(kāi)發(fā)代碼

2016-12-26 17:57:13

戴爾成就篇

2018-10-30 16:39:12

雙頻WiFi雙路

2010-03-09 16:38:22

Linux grub啟

2009-06-11 13:00:08

Java數(shù)組賦值

2010-07-08 12:49:12

SIP會(huì)話發(fā)起協(xié)議
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

亚洲综合日韩在线| 色妞在线综合亚洲欧美| 国产精品国产亚洲精品看不卡| 神宫寺奈绪一区二区三区| 久久久久国产精品午夜一区| 色噜噜狠狠狠综合曰曰曰88av| 蜜臀aⅴ国产精品久久久国产老师| 成人美女视频| 亚洲精品国久久99热| 免费一区二区三区| 国产黄色高清视频| 日本在线不卡视频| 欧美激情亚洲自拍| 日韩视频在线观看免费视频| 亚洲图色一区二区三区| 在线亚洲人成电影网站色www| 男同互操gay射视频在线看| 天堂网av在线播放| 国产精品中文字幕一区二区三区| 清纯唯美日韩制服另类| 久久久久久久黄色| 成人在线免费观看网站| 亚洲国产三级网| 五月激情五月婷婷| 免费成人美女女| 亚洲国产视频在线| 亚洲色图都市激情| 777电影在线观看| 91麻豆国产精品久久| 99影视tv| 国产欧美一级片| 蜜臀av性久久久久蜜臀aⅴ| 亚州精品天堂中文字幕| 黄色一级片中国| 成人看的视频| 亚洲欧洲在线看| 国产精品无码在线| av在线亚洲色图| 日韩精品一区二区三区在线| a级大片免费看| 免费成人黄色网| 91成人免费电影| 精品少妇无遮挡毛片| 激情国产在线| 欧美日韩国产区| 777av视频| xxx在线免费观看| 亚洲国产三级在线| 免费无码毛片一区二三区| 调教一区二区| 亚洲自拍偷拍网站| 日韩美女爱爱视频| 成人免费一区二区三区牛牛| 一区二区免费在线播放| 日本大片免费看| 牛牛电影国产一区二区| 亚洲综合在线视频| 久久手机在线视频| 123区在线| 亚洲国产视频在线| 欧美日本视频在线观看| 是的av在线| 日韩欧美在线免费观看| 999精品视频在线| 久久久久久久性潮| 4438x亚洲最大成人网| 三上悠亚 电影| 国内露脸中年夫妇交换精品| 亚洲国产成人久久综合| 噜噜噜在线视频| 九一国产精品| 丝袜亚洲另类欧美重口| 日本不卡一二区| 国产精品chinese| 91国内免费在线视频| av手机天堂网| 国内精品视频666| 国产精品一区二区三区免费观看| 天天综合网在线| 久久久九九九九| 在线天堂一区av电影| a毛片在线看免费观看| 午夜精品久久久久久久久| 免费观看精品视频| 亚州欧美在线| 亚洲国产成人在线视频| 亚洲av熟女国产一区二区性色| 欧美成人自拍| 国内偷自视频区视频综合| 日韩在线播放中文字幕| 国模大尺度一区二区三区| 国产精品有限公司| 成人影视在线播放| 亚洲美女视频在线观看| 中文字幕日本最新乱码视频| 亚洲青青一区| 亚洲精品91美女久久久久久久| 久久久久久久毛片| 亚洲午夜精品久久久久久app| 日本成人免费在线| a级片在线播放| 91欧美一区二区| 国产资源第一页| 欧美xnxx| 亚洲精品ady| 国产精品免费在线视频| 性一交一乱一区二区洋洋av| 亚洲tv在线观看| 国产在线视频网址| 亚洲a一区二区| 日本中文字幕观看| 国产成人精品免费视| 九九热精品视频国产| 亚洲av无码不卡| 丁香桃色午夜亚洲一区二区三区| 亚洲国产另类久久久精品极度| 欧美大片黄色| 884aa四虎影成人精品一区| www.自拍偷拍| 亚洲第一黄网| 7777奇米亚洲综合久久| 日本三级视频在线观看| 色综合视频在线观看| 动漫av在线免费观看| 99久久www免费| 国产91热爆ts人妖在线| 天天综合天天色| 亚洲一区二区三区美女| 日韩av福利在线观看| 日韩中字在线| 国产精品直播网红| 国产福利小视频在线观看| 狠狠操狠狠色综合网| 妖精视频一区二区| 一区二区三区毛片免费| 国产欧美日韩高清| 95在线视频| 精品视频123区在线观看| 无码国产69精品久久久久同性| 国产精品久久久久久久免费软件| 国产精品.com| jizzjizz中国精品麻豆| 亚洲第一精品福利| 国产精品美女毛片真酒店| 国产成人丝袜美腿| 欧美 日韩 国产精品| 成人免费91| 久久久成人av| 国产三级第一页| 亚洲日本中文字幕区| 日本中文字幕在线不卡| 欧美一区久久| 国产九色精品| www.九色在线| 日韩av在线免费看| 免费的毛片视频| 亚洲国产成人自拍| 国产美女视频免费看| 91精品亚洲| 99久久无色码| av资源网在线播放| 亚洲精品视频免费在线观看| www.日韩一区| 国产精品夫妻自拍| 性色av浪潮av| 99精品热视频只有精品10| 欧美二级三级| 欧美少妇激情| 欧美日韩国产91| 无码精品视频一区二区三区 | 日韩一区二区不卡| 欧美一级高潮片| 26uuuu精品一区二区| 成人亚洲精品777777大片| 91精品一区二区三区综合在线爱| 成人免费视频网站| 韩日精品一区二区| 久久亚洲成人精品| 天天干,夜夜爽| 欧美午夜片在线看| 欧美片一区二区| 久久综合五月天婷婷伊人| 国产喷水theporn| 欧美另类视频| 欧美一区二区三区精美影视| 99tv成人影院| 欧美亚洲一级片| 久操视频在线| 亚洲乱码一区二区| 国产精品系列视频| 欧美日韩激情网| 精品在线观看一区| 成人动漫在线一区| 一区二区三区网址| 亚洲深夜av| 免费观看黄色的网站| 老汉色老汉首页av亚洲| 国产精品亚洲综合天堂夜夜| 爱啪视频在线观看视频免费| 色噜噜国产精品视频一区二区| 免费a级片在线观看| 欧美网站大全在线观看| 国产在线免费视频| 国产精品久久福利| 免费成人深夜夜行p站| 精品综合久久久久久8888| 国产成人亚洲精品无码h在线| 天天做天天爱综合| 欧美色欧美亚洲另类七区| 综合中文字幕| 91九色国产社区在线观看| 手机在线看福利| 色一情一区二区三区| 国产videos久久| 91久久精品www人人做人人爽| 日韩av福利| 欧美激情亚洲精品| 巨大荫蒂视频欧美大片| 国产午夜一区二区| 性插视频在线观看| 日韩欧美不卡在线观看视频| 亚洲综合一区中| 色婷婷激情综合| 久久免费激情视频| 亚洲最大成人综合| 杨钰莹一级淫片aaaaaa播放| 国产精品―色哟哟| 中字幕一区二区三区乱码| 99久精品国产| 精品1卡二卡三卡四卡老狼| 国产一区二区女| 男人的天堂最新网址| 日韩av一二三| 国产三级三级三级看三级| 国产一区二区三区的电影 | 午夜一区二区三区不卡视频| 青青草国产精品视频| 亚洲小说欧美另类婷婷| 97超碰在线视| 黄色成人在线网址| 国产91视频一区| 国产综合视频| 欧美视频在线观看视频| 黄色在线成人| heyzo亚洲| 美女网站久久| 免费男同深夜夜行网站 | 国产91在线播放九色快色| 爱搞国产精品| 欧美亚洲另类在线| 少妇一区视频| 国产精品入口日韩视频大尺度 | av一区二区三区四区电影| 麻豆精品一区| 成人动漫视频在线观看完整版| 中文无码日韩欧| 国产精品日本一区二区| 色先锋久久影院av| 日韩免费三级| 99免费精品| 大陆极品少妇内射aaaaaa| 黄色成人91| 黄色片久久久久| 久久福利资源站| 在线成人精品视频| 成人激情校园春色| 亚洲激情视频小说| 国产精品久久久久一区| 国产一二三区精品| 亚洲福利电影网| 精产国品一区二区| 欧美日韩国产天堂| 亚洲第一精品网站| 亚洲精品午夜精品| 日本高清视频在线播放| 欧美黄色片视频| 中文av在线全新| 国产在线98福利播放视频| 一区二区三区亚洲变态调教大结局| 精品久久久久久中文字幕动漫| 九色精品国产蝌蚪| 热久久最新网址| 久久都是精品| 久久久福利影院| 99久久精品国产麻豆演员表| 国产精品麻豆免费版现看视频| 一区二区成人在线| 国产亚洲欧美在线精品| 欧美一区二区黄| 九色国产在线观看| 久操成人在线视频| 性欧美1819sex性高清| 亚洲www视频| 国产日韩欧美一区二区三区| 国产精品av免费观看| 天堂在线亚洲视频| 在线精品视频播放| 中文字幕第一区综合| 日韩精品久久久久久久酒店| 欧美日韩极品在线观看一区| 国内爆初菊对白视频| www国产精品视频| 最新中文字幕在线播放| 99国产超薄肉色丝袜交足的后果| 国产一区二区在线| www.射射射| 国产精品1区2区3区在线观看| 天天躁夜夜躁狠狠是什么心态| 亚洲一区二区三区四区在线观看 | 国产老女人精品毛片久久| 爱爱免费小视频| 亚洲尤物视频在线| 国产永久免费视频| 亚洲网站在线观看| 阿v视频在线观看| 成人黄动漫网站免费| 国产大片一区| 亚洲欧洲日本精品| 久久久国产精华| 日韩少妇裸体做爰视频| 日韩欧美一区在线| 麻豆传媒视频在线观看免费| 国产成人自拍视频在线观看| 日韩成人av在线资源| 男人添女人下部视频免费| 久久www免费人成看片高清| 亚洲午夜福利在线观看| 欧美日韩另类视频| 色欲av伊人久久大香线蕉影院| 欧美精品在线播放| 电影91久久久| 一区二区三区四区不卡| 日韩av不卡在线观看| 无码 人妻 在线 视频| 黑人巨大精品欧美一区二区| 老司机午夜福利视频| 欧美极品少妇全裸体| 亚洲小说春色综合另类电影| 97av中文字幕| 国产精品中文有码| 成人在线观看高清| 91精品欧美福利在线观看| 麻豆网站在线观看| 国产精品综合网站| 99久久精品网站| 亚洲一级片免费| 亚洲欧洲日韩在线| 国产精品无码AV| 操91在线视频| 97一区二区国产好的精华液| www.avtt| 91啪亚洲精品| 亚洲欧美一二三区| 中文字幕亚洲精品| 不卡一区视频| 国产成a人亚洲精v品在线观看| 丰满放荡岳乱妇91ww| 国产成人愉拍精品久久| 日韩精品免费视频| 91成人抖音| 宅男av一区二区三区| 国产成人高清视频| 天天综合网久久综合网| 亚洲丝袜av一区| 亚洲ww精品| 久久久久久www| 91视频精品在这里| 中文字幕av网站| 久久这里有精品| 久草在线综合| 国产主播中文字幕| 亚洲啪啪综合av一区二区三区| 秋霞网一区二区| 国产精品99一区| 欧美日韩18| 国产精品扒开腿做爽爽| 欧美高清视频不卡网| 青草av在线| 免费精品视频一区| 久久 天天综合| 天天插天天操天天干| 亚洲欧美国产高清va在线播| 色综合久久久| 91免费视频网站在线观看| 国产精品看片你懂得| 女人18毛片水真多18精品| 国产精品久久久久久亚洲影视| 综合激情网站| 国产熟妇久久777777| 欧美一区二区免费| 樱桃视频成人在线观看| 中文字幕精品—区二区日日骚| 成人激情午夜影院| 亚洲午夜精品久久久| 97国产成人精品视频| 999精品色在线播放| 小毛片在线观看| 91精品国产手机| 久九九久频精品短视频| 天天做天天躁天天躁|