亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java并發(fā)編程StampedLock高性能讀寫鎖詳解

 更新時間:2022年05月16日 08:43:25   作者:字母哥  
這篇文章主要為大家介紹了java并發(fā)編程StampedLock高性能讀寫鎖的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

一、讀寫鎖

在我的《java并發(fā)編程》上一篇文章中為大家介紹了《ReentrantLock讀寫鎖》,ReentrantReadWriteLock可以保證最多同時有一個線程在寫數(shù)據(jù),或者可以同時有多個線程讀數(shù)據(jù),但讀寫不能同時進行。

比如你正在做的是日志,有一個線程正在做寫操作,但是在寫日志的時候你可能需要把日志集中轉(zhuǎn)移到集中管理日志服務(wù),但是此時讀線程不能讀數(shù)據(jù)(因為無法獲取讀鎖)。面對這個需求,ReentrantReadWriteLock顯然不是我們的解決方案,我們希望:最多一個線程在進行寫操作(加寫鎖),但是同時允許多個線程進行讀操作(加讀鎖),解決方案是StampedLock。

二、悲觀讀鎖

StampedLock 同樣可以實現(xiàn)寫鎖和讀鎖的功能,Stamped在英文中有印章的含義,對于StampedLock大家可以這么理解,使用一個印章加鎖,必須使用該印章解鎖。

public class TestStampedLock {
    Map<String,String> map = new HashMap<>();
    //鎖對象
    private StampedLock lock = new StampedLock();
    //寫操作函數(shù)
    public void put(String key, String value){
        long stamp = lock.writeLock(); //加寫鎖
        try {
            map.put(key, value); //寫操作
        } finally {
            lock.unlockWrite(stamp);  //釋放寫鎖
        }
    }
    public String get(String key) {
        long stamp = lock.readLock(); //加讀鎖
        try {
            return map.get(key); //讀操作
        } finally {
            lock.unlockRead(stamp); //釋放讀鎖
        }
    }
}

上文中的讀鎖readLock,在StampedLock模式中被稱為悲觀讀鎖,之所以叫做悲觀讀鎖是和StampedLock支持的另一種模式“樂觀讀”相對應的。

寫鎖、悲觀讀鎖的語義和 ReadWriteLock 的寫鎖、讀鎖的語義基本是一致的,允許多個線程同時獲取悲觀讀鎖,但是只允許一個線程獲取寫鎖,寫鎖和悲觀讀鎖是互斥的。

多線程環(huán)境下,寫操作的同時不能讀。所以到這里為止,StampedLock與ReadWriteLock并沒有很大的區(qū)別。

三、樂觀讀

需要注意的是,這里我寫的是樂觀讀,而不是樂觀讀鎖,因為樂觀讀是不加鎖的。通過tryOptimisticRead()函數(shù)獲取一個stamp,這里的tryOptimisticRead() 就是樂觀讀,樂觀讀因為沒有加鎖,所以讀取數(shù)據(jù)的性能會更高一點。即:已經(jīng)有寫操作線程加鎖的同時,仍然允許讀操作線程繼續(xù)進行。

如果你的讀寫操作有比較強的時間點數(shù)據(jù)一致性要求,即:同一個時間點讀操作讀到的數(shù)據(jù),一定與該時間點寫操作保持數(shù)據(jù)一致性。那么,你就需要進行validate校驗,stamp此時可以理解為一個版本號,如果寫操作版本為2,讀操作版本為1,說明你讀到的數(shù)據(jù)不是最新的。你需要去讀取最新版本的數(shù)據(jù)(版本號為2),所以需要升級為悲觀讀鎖,代碼如下:

public String readWithOptimisticLock(String key) {
    long stamp = lock.tryOptimisticRead(); //樂觀讀
    String value = map.get(key); //讀取數(shù)據(jù)
    if(!lock.validate(stamp)) {  //校驗數(shù)據(jù)是否是最新版本
        stamp = lock.readLock();  //如果不是,升級為悲觀讀鎖
        try {
            return map.get(key);
        } finally {
            lock.unlock(stamp);               
        }
    }
    return value;
}

以上就是java并發(fā)編程StampedLock高性能讀寫鎖詳解的詳細內(nèi)容,更多關(guān)于java并發(fā)StampedLock讀寫鎖的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • SpringBoot中使用websocket出現(xiàn)404的解決方法

    SpringBoot中使用websocket出現(xiàn)404的解決方法

    在Springboot中使用websocket時,本地開發(fā)環(huán)境可以正常運行,但部署到服務(wù)器環(huán)境出現(xiàn)404問題,所以本文小編講給大家詳細介紹一下SpringBoot中使用websocket出現(xiàn)404的解決方法,需要的朋友可以參考下
    2023-09-09
  • Java看完秒懂版熔斷和降級的關(guān)系

    Java看完秒懂版熔斷和降級的關(guān)系

    這篇文章主要介紹了Java熔斷和降級的關(guān)系,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • 舉例講解JDK注解的使用和自定義注解的方法

    舉例講解JDK注解的使用和自定義注解的方法

    今天小編就為大家分享一篇關(guān)于舉例講解JDK注解的使用和自定義注解的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • Java之Mybatis的二級緩存

    Java之Mybatis的二級緩存

    本文主要介紹Java中Mybatis的二級緩存,緩存就是一塊內(nèi)存空間,保存臨時數(shù)據(jù),它是SqlSessionFactory的緩存,對Mybaits感興趣的小伙伴可以參考閱讀
    2023-03-03
  • 詳解IDEA啟動多個微服務(wù)的配置方法

    詳解IDEA啟動多個微服務(wù)的配置方法

    這篇文章主要介紹了詳解IDEA啟動多個微服務(wù)的配置方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-01-01
  • Java 文創(chuàng)商城系統(tǒng)的實現(xiàn)流程

    Java 文創(chuàng)商城系統(tǒng)的實現(xiàn)流程

    讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+mysql+maven+tomcat實現(xiàn)一個文創(chuàng)商城系統(tǒng),大家可以在過程中查缺補漏,提升水平
    2021-11-11
  • maven中pom.xml詳細介紹

    maven中pom.xml詳細介紹

    最近在學習maven,這篇文章主要介紹了maven中pom.xml詳細介紹,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • Java實現(xiàn)簡易圖書借閱系統(tǒng)

    Java實現(xiàn)簡易圖書借閱系統(tǒng)

    這篇文章主要為大家詳細介紹了Java實現(xiàn)簡易圖書借閱系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Spring?Boot?Admin集成與自定義監(jiān)控告警示例詳解

    Spring?Boot?Admin集成與自定義監(jiān)控告警示例詳解

    SpringBootAdmin是一個管理和監(jiān)控SpringBoot應用程序的工具,可通過集成和配置實現(xiàn)應用監(jiān)控與告警功能,本文給大家介紹Spring?Boot?Admin集成與自定義監(jiān)控告警示例詳解,感興趣的朋友跟隨小編一起看看吧
    2024-09-09
  • SpringBoot+Redis實現(xiàn)數(shù)據(jù)字典的方法

    SpringBoot+Redis實現(xiàn)數(shù)據(jù)字典的方法

    這篇文章主要介紹了SpringBoot+Redis實現(xiàn)數(shù)據(jù)字典的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-10-10

最新評論