並發情況下synchronized死結

來源:互聯網
上載者:User

存在缺陷的代碼:

public class DataPropertyIdAndNameRepositoryImpl{    /** 發布標誌 */    private volatile boolean                      publishFlag;    public Integer getStandardId(int dataId, String propertyName) {        if (!publishFlag) {            loadToCache();        }        Integer standardId = 0;        Map<String, Integer> propertyIdMap = propertyIdLocalCache.get(dataId);        if (propertyIdMap != null) {            standardId = propertyIdMap.get(propertyName);        }        return standardId;    }    public synchronized boolean loadToCache() {        try {            DataPropertyIdAndName dataPropertyIdAndName = dataPropertyIdAndNameService                .queryDataPropertyIdAndName();            publishFlag = true;        } catch (Exception e) {            publishFlag = false;        }        return publishFlag;    }}

存在缺陷的流程:

a. 綠色表示第一個線程,藍色表示第二個線程。

b. 黃色模組的代碼為synchronized標記的代碼,並發情況下只會有一個線程執行此方法。

c. 綠色線程執行到紫色模組時,藍色線程等待進入黃色模組。

d. 藍色線程執行拋異常,導致publishFlag被置為false。

e. 此時再次有線程進入,判斷publishFlag仍為false,因此導致重複不斷載入loadToCache.



修複後的代碼:

public class DataPropertyIdAndNameRepositoryImpl{    /** 發布標誌 */    private volatile boolean                      publishFlag;    public Integer getStandardId(int dataId, String propertyName) {        if (!publishFlag) {            loadToCache();        }        Integer standardId = 0;        Map<String, Integer> propertyIdMap = propertyIdLocalCache.get(dataId);        if (propertyIdMap != null) {            standardId = propertyIdMap.get(propertyName);        }        return standardId;    }    public synchronized boolean loadToCache() {        try {            // 雙檢鎖            if (publishFlag) {                return publishFlag;            }            DataPropertyIdAndName dataPropertyIdAndName = dataPropertyIdAndNameService.queryDataPropertyIdAndName();            publishFlag = true;        } catch (Exception e) {            publishFlag = false;        }        return publishFlag;    }}




相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.