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

Java 高并發(fā)的三種實現(xiàn)案例詳解

 更新時間:2021年08月31日 14:09:03   作者:java_xth  
這篇文章主要介紹了Java 高并發(fā)的三種實現(xiàn)案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下

提到鎖,大家肯定想到的是sychronized關鍵字。是用它可以解決一切并發(fā)問題,但是,對于系統(tǒng)吞吐量要求更高的話,我們這提供幾個小技巧。幫助大家減小鎖顆粒度,提高并發(fā)能力。

初級技巧-樂觀鎖

樂觀鎖使用的場景是,讀不會沖突,寫會沖突。同時讀的頻率遠大于寫。

 悲觀鎖的實現(xiàn)

悲觀的認為所有代碼執(zhí)行都會有并發(fā)問題,所以將所有代碼塊都用sychronized鎖住

樂觀鎖的實現(xiàn)

樂觀的認為在讀的時候不會產生沖突為題,在寫時添加鎖。所以解決的應用場景是讀遠大于寫時的場景。

中級技巧-String.intern()

樂觀鎖不能很好的解決大量的寫沖突的問題,但是很多場景下,鎖只是針對某個用戶或者某個訂單。 比如一個用戶先創(chuàng)建session,才能進行后面的操作,但是由于網絡的問題,創(chuàng)建session的請求和后續(xù)請求幾乎同時到達,而并行線程可能會先處理后面的請求。一般情況需要對用戶sessionMap加鎖,比如上面的樂觀鎖。在這樣的場景下,可以將鎖限定在用戶本身上,即原來的

這個比較類似行鎖和數(shù)據(jù)庫表鎖的概念。顯然行鎖的并發(fā)能力比表鎖的高很多。

實用String.intern();是這種方式的具體實現(xiàn)。類String維護了一個字符串池。當調用intern方法時,如果池已經包含一個等于此String對象的字符串(該對象由equals(Object)方法確定),則返回池中的字符串??梢?,當String 相同時,總返回同一個對象,因此就實現(xiàn)了對同一用戶加鎖。由于所的顆粒度局限于具體用戶,使得系統(tǒng)獲得最大程度的并發(fā)。

CopyOnWriteMap?

既然說到了“類似于數(shù)據(jù)庫中的行鎖的概念”,就不得不提一下MVCC,Java中CopyOnWrite類實現(xiàn)了MVCC。Copy On Write是這樣一種機制。當我們讀取共享數(shù)據(jù)的時候,直接讀取,不需要同步。當我們修改數(shù)據(jù)的時候,我們就把當前數(shù)據(jù)Copy一份副本,然后在這個副本 上進行修改,完成之后,再用修改后的副本,替換掉原來的數(shù)據(jù)。這種方法就叫做Copy On Write。

但是,,,JDK并沒有提供CopyOnWriteMap,為什么?下面有個很好的回答,那就是已經有了ConcurrentHashMap,為什么還需要CopyOnWriteMap?

高級技巧 - 類ConcurrentHashMap

String.inter()的缺陷是類 String 維護一個字符串池是放在JVM perm區(qū)的,如果用戶數(shù)特別多,導致放入字符串池的String不可控,有可能導致OOM錯誤或者過多的Full GC。怎么樣能控制鎖的個數(shù),同時減小粒度鎖呢?直接使用Java ConcurrentHashMap?或者你想加入自己更精細的控制?那么可以借鑒ConcurrentHashMap的方式,將需要加鎖的對象分為多個bucket,每個bucket加一個鎖,偽代碼如下:

到此這篇關于Java 高并發(fā)的三種實現(xiàn)案例詳解的文章就介紹到這了,更多相關Java 高并發(fā)的三種實現(xiàn)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java簡單高效實現(xiàn)分頁功能

    Java簡單高效實現(xiàn)分頁功能

    這篇文章主要介紹了Java簡單高效實現(xiàn)分頁功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-08-08
  • 教你怎么用Java實現(xiàn)給圖片打上水印

    教你怎么用Java實現(xiàn)給圖片打上水印

    這篇文章主要介紹了教你怎么用Java實現(xiàn)給圖片打上水印,文中有非常詳細的代碼示例,對正在學習java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • SpringBoot2 JPA解決懶加載異常的問題

    SpringBoot2 JPA解決懶加載異常的問題

    這篇文章主要介紹了SpringBoot2 JPA解決懶加載異常的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Feign調用中的兩種Header傳參方式小結

    Feign調用中的兩種Header傳參方式小結

    這篇文章主要介紹了Feign調用中的兩種Header傳參方式小結,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • iReport生成pdf打印的實例代碼

    iReport生成pdf打印的實例代碼

    下面小編就為大家分享一篇iReport生成pdf打印的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-11-11
  • SpringCloud2020整合Nacos-Bootstrap配置不生效的解決

    SpringCloud2020整合Nacos-Bootstrap配置不生效的解決

    這篇文章主要介紹了SpringCloud2020整合Nacos-Bootstrap配置不生效的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • java中Date類和Strng類的靈活轉化

    java中Date類和Strng類的靈活轉化

    這篇文章主要介紹了java中Date類和Strng類的靈活轉化,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • java異常繼承何類,運行時異常與一般異常的區(qū)別(詳解)

    java異常繼承何類,運行時異常與一般異常的區(qū)別(詳解)

    下面小編就為大家?guī)硪黄猨ava異常繼承何類,運行時異常與一般異常的區(qū)別(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • java自定義任務類定時執(zhí)行任務示例 callable和future接口使用方法

    java自定義任務類定時執(zhí)行任務示例 callable和future接口使用方法

    Callable是類似于Runnable的接口,實現(xiàn)Callable接口的類和實現(xiàn)Runnable的類都是可被其它線程執(zhí)行的任務
    2014-01-01
  • SpringBoot使用Redis單機版過期鍵監(jiān)聽事件的實現(xiàn)示例

    SpringBoot使用Redis單機版過期鍵監(jiān)聽事件的實現(xiàn)示例

    在緩存的使用場景中經常需要使用到過期事件,本文主要介紹了SpringBoot使用Redis單機版過期鍵監(jiān)聽事件的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-07-07

最新評論