国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Java中的5種同步輔助類介紹

2019-11-26 15:32:05
字體:
供稿:網(wǎ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ù)并返回。當兩個線程通過Exchanger交換了對象,這個交換對于兩個線程來說都是安全的。Exchanger可以認為是 SynchronousQueue 的雙向形式,在運用到遺傳算法和管道設(shè)計的應(yīng)用中比較有用。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 化隆| 陕西省| 武陟县| 乐山市| 镇安县| 双牌县| 松江区| 盖州市| 宜宾市| 汉川市| 潼南县| 广安市| 枣阳市| 长泰县| 兴宁市| 定远县| 青海省| 通海县| 增城市| 盖州市| 襄城县| 浦县| 华坪县| 吴堡县| 桐梓县| 永城市| 惠水县| 治多县| 峨边| 永泰县| 秭归县| 建平县| 汉阴县| 新余市| 大宁县| 舞阳县| 比如县| 河东区| 宁安市| 准格尔旗| 平顺县|