Java中的5種同步輔助類介紹
當(dāng)你使用synchronized關(guān)鍵字的時候,是通過互斥器來保障線程安全以及對共享資源的同步訪問。線程間也經(jīng)常需要更進一步的協(xié)調(diào)執(zhí)行,來完成復(fù)雜的并發(fā)任務(wù),比如wait/notify模式就是一種在多線程環(huán)境下的協(xié)調(diào)執(zhí)行機制。
通過API來獲取和釋放鎖(使用互斥器)或者調(diào)用wait/notify等方法都是底層調(diào)用的方式。進一步來說,有必要為線程同步創(chuàng)建更高層次的抽象。通常用到的同步輔助類,就是對2個或多個線程間的同步活動機制做進一步封裝,其內(nèi)部原理是通過使用現(xiàn)有的底層API來實現(xiàn)復(fù)雜的線程間的協(xié)調(diào)。
有5種同步輔助類適用于常見的同步場景:
1. Semaphore 信號量是一類經(jīng)典的同步工具。信號量通常用來限制線程可以同時訪問的(物理或邏輯)資源數(shù)量。
2.CountDownLatch 一種非常簡單、但很常用的同步輔助類。其作用是在完成一組正在其他線程中執(zhí)行的操作之前,允許一個或多個線程一直阻塞。
3.CyclicBarrier 一種可重置的多路同步點,在某些并發(fā)編程場景很有用。它允許一組線程互相等待,直到到達某個公共的屏障點 (common barrier point)。在涉及一組固定大小的線程的程序中,這些線程必須不時地互相等待,此時 CyclicBarrier 很有用。因為該 barrier在釋放等待線程后可以重用,所以稱它為循環(huán)的barrier。
4.Phaser 一種可重用的同步屏障,功能上類似于CyclicBarrier和CountDownLatch,但使用上更為靈活。非常適用于在多線程環(huán)境下同步協(xié)調(diào)分階段計算任務(wù)(Fork/Join框架中的子任務(wù)之間需同步時,優(yōu)先使用Phaser)
5.Exchanger 允許兩個線程在某個匯合點交換對象,在某些管道設(shè)計時比較有用。Exchanger提供了一個同步點,在這個同步點,一對線程可以交換數(shù)據(jù)。每個線程通過exchange()方法的入口提供數(shù)據(jù)給他的伙伴線程,并接收他的伙伴線程提供的數(shù)據(jù)并返回。當(dāng)兩個線程通過Exchanger交換了對象,這個交換對于兩個線程來說都是安全的。Exchanger可以認為是 SynchronousQueue 的雙向形式,在運用到遺傳算法和管道設(shè)計的應(yīng)用中比較有用。
相關(guān)文章
Maven install 報錯"程序包不存在"問題的解決方法
這篇文章主要介紹了Maven install 報錯"程序包不存在"問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07如何在Intellij中安裝LeetCode刷題插件方便Java刷題
這篇文章主要介紹了如何在Intellij中安裝LeetCode刷題插件方便Java刷題,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08SpringMVC中的DispatcherServlet詳細解析
這篇文章主要介紹了SpringMVC中的DispatcherServlet詳細解析,DispatcherServlet也是一個Servlet,它也能通過Servlet的API來響應(yīng)請求,從而成為一個前端控制器,Web容器會調(diào)用Servlet的doGet()以及doPost()等方法,需要的朋友可以參考下2023-12-12