<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    ThreadLocal與synchronized

    Posted on 2009-08-25 20:36 林光炎 閱讀(980) 評論(0)  編輯  收藏 所屬分類: JAVA

    相關文章:  
    正確理解ThreadLocal
    ThreadLocal與synchronized

    推薦圈子: Pipboy
    更多相關推薦
    昨天上Java版塊逛了一圈,一個2萬5千人瀏覽的帖子引起了偶滴注意 ThreadLocal與synchronized ,9頁以上的回復,足見大家對這個問題的興趣。

    老實說,從看到這個帖子的題目開始,就覺得帖子的作者估計是在概念上有所混淆了,于是乎想寫個咚咚,同大家分享一下自己的心得。

    帖子上,討論的人很多,高手不乏,各抒己見,但不知新手們看明白沒有,因此,這里偶以最簡潔列表方式來說一說相關問題。

    1.區別ThreadLocal 與 synchronized

    ThreadLocal是一個線程隔離(或者說是線程安全)的變量存儲的管理實體(注意:不是存儲用的),它以Java類方式表現;
    synchronized是Java的一個保留字,只是一個代碼標識符,它依靠JVM的鎖機制來實現臨界區的函數、變量在CPU運行訪問中的原子性。
    兩者的性質、表現及設計初衷不同,因此沒有可比較性。

    2.理解ThreadLocal中提到的變量副本
    事實上,我們向ThreadLocal中set的變量不是由ThreadLocal來存儲的,而是Thread線程對象自身保存。當用戶調用ThreadLocal對象的set(Object o)時,該方法則通過Thread.currentThread()獲取當前線程,將變量存入Thread中的一個Map內,而Map的Key就是當前的ThreadLocal實例。請看源碼,這是最主要的兩個函數,能看出ThreadLocal與Thread的調用關系:

    Java代碼
    public void set(T value) {   
            Thread t = Thread.currentThread();   
            ThreadLocalMap map = getMap(t);   
            if (map != null)   
                map.set(this, value);   
            else  
                createMap(t, value);   
    }   
      
    ThreadLocalMap getMap(Thread t) {   
            return t.threadLocals;   
    }  
    public void set(T value) {
            Thread t = Thread.currentThread();
            ThreadLocalMap map = getMap(t);
            if (map != null)
                map.set(this, value);
            else
                createMap(t, value);
    }

    ThreadLocalMap getMap(Thread t) {
            return t.threadLocals;
    }

    (有興趣的朋友可以閱讀Java的ThreadLocal源碼)因此,我們可以知道,所謂的變量副本,即是對Object Reference(對象引用)的拷貝。

    3.理解Thread和 ThreadLocal對變量的引用關系
    實際上Thread和ThreadLocal對變量引用關系就像是坐標系中的X軸和Y軸,是從兩個維度上來組織對變量的引用的。

    首先說Thread。 我們知道一個ThreadOne的執行會貫穿多個方法MethodA、MethodB、MethodC這些方法可能分布于不同的類實例。假設,這些方法分別使用了ThreadLocalA、ThreadLocalB、ThreadLocalC來保存線程本地變量,那么這些變量都存于ThreadOne的Map中,并使用各自的ThreadLocal實例作為key。 因此,可以認為,借助ThreanLocal的set方法,在X軸上,Thread橫向關聯同一線程上下文中來自多個Method的變量引用副本。


     


    接著說ThreadLocal。 一個MethodA中的X變量將被多個線程ThreadOne、ThreadTwo、ThreadThree所訪問。假設MethodA使用ThreadLocal存儲X,通過set方法,以ThreadLocal作為key值,將不同線程來訪時的不同的變量值引用保存于ThreadOne、ThreadTwo、ThreadThree的各自線程上下文中,確保每個線程有自己的一個變量值。因此,可以認為,ThreadLocal是以Method為Y軸,縱向關聯了處于同一方法中的不同線程上的變量。


     

    希望能對大家有所幫助,這樣可以少走很多彎路哦。

    本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/yangairong1984/archive/2008/04/15/2294572.aspx

    posts - 104, comments - 33, trackbacks - 0, articles - 0

    Copyright © 林光炎

    主站蜘蛛池模板: 亚洲成AV人片在线观看| 免费精品国产自产拍观看| 亚洲精品卡2卡3卡4卡5卡区| 免费一级全黄少妇性色生活片| 国产高清在线免费| 亚洲Av无码国产一区二区| 国产成人aaa在线视频免费观看 | 亚洲美女在线观看播放| 日本免费中文字幕| 亚洲色成人网一二三区| 99久久99这里只有免费费精品| 亚洲自国产拍揄拍| 性xxxx视频播放免费| 国产成人高清亚洲一区91| 国产成人免费片在线视频观看| 美女露100%胸无遮挡免费观看| 四虎影在线永久免费四虎地址8848aa| 麻豆va在线精品免费播放| 亚洲欧洲∨国产一区二区三区| 久久美女网站免费| 在线精品亚洲一区二区| 全黄性性激高免费视频| 成人免费乱码大片A毛片| 久久精品国产亚洲AV麻豆不卡| 亚洲精品国产免费| 亚洲av永久无码| 国产gv天堂亚洲国产gv刚刚碰| 免费国产成人α片| 亚洲AV男人的天堂在线观看| 国产一区二区免费在线| 久久国产精品免费一区二区三区| 亚洲精品高清国产一久久| 91视频国产免费| 国产99精品一区二区三区免费| 亚洲国产一区国产亚洲| 日本高清免费网站| 永久免费不卡在线观看黄网站| 精品亚洲成在人线AV无码| 亚洲高清无码专区视频| 亚洲电影在线免费观看| 猫咪www免费人成网站|