日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

java并發編程專題(九)----(JUC)淺析CyclicBarrier

瀏覽:21日期:2022-08-29 18:05:06

上一篇我們介紹了CountDownlatch,我們知道CountDownlatch是“在完成一組正在其他線程中執行的操作之前,它允許一個或多個線程一直等待”,即CountDownLatch的作用是允許1或N個線程等待其他線程完成執行,而我們今天要介紹的CyclicBarrier則是允許N個線程相互等待。

1.CyclicBarrier簡介

CyclicBarrier 的字面意思是可循環使用(Cyclic)的屏障(Barrier)。它要做的事情是,讓一組線程到達一個屏障(也可以叫同步點)時被阻塞,直到最后一個線程到達屏障時,屏障才會開門,所有被屏障攔截的線程才會繼續干活。 在JDK中對CyclicBarrier是這樣說的“允許一組線程全部等待彼此到達公共屏障點的同步輔助。 循環障礙在涉及必須偶爾彼此等待的固定大小的線程程序中是有用的。屏障稱為循環 ,因為它可以在等待線程釋放后重新使用”。CountDownLatch的計數器無法被重置;CyclicBarrier的計數器可以被重置后使用,因此它被稱為是循環的barrier。

我們先來看一下他的構造方法和使用方式:

構造函數: CyclicBarrier(int parties) //其參數表示屏障攔截的線程數量,每個線程調用await方法告 訴CyclicBarrier我已經到達了屏障,然后當前線程被阻塞。

CyclicBarrier (int parties, Runnable barrierAction) //創建一個新的CyclicBarrier ,當給定數量的參與者(線程)等待它時,它將跳閘,當障礙跳閘時,它將執行 給定的障礙動作(Runnable參數提供),由最后一個線程進入障礙。

方法: int await() //在所有參與者都已經在此 barrier 上調用 await 方法之前,將一直等待。 方法之前將一直等待,或者超出了指定的等待時間。 int getNumberWaiting() //返回當前在屏障處等待的參與者數目。 int getParties()//返回要求啟動此 barrier 的參與者數目。 boolean isBroken() //查詢此屏障是否處于損壞狀態。 void reset() //將屏障重置為其初始狀態。

下面我們來看一個小程序了解一下CyclicBarrier的使用方式:

public class CyclicBarrierTest { static CyclicBarrier c = new CyclicBarrier(2); public static void main(String[] args) { new Thread(new Runnable() { @Override public void run() {try { c.await();} catch (Exception e) {}System.out.println(Thread.currentThread().getName()+'正在等待...'); } }).start(); try { c.await(); } catch (Exception e) { } System.out.println(Thread.currentThread().getName()+'正在等待...'); System.out.println('人夠了,出發吧 當前有 '+c.getParties()+' 個人參與比賽'); }}

輸出結果為:

Thread-0正在等待...main正在等待...人夠了,出發吧 當前有 2 個人參與比賽

Process finished with exit code 0

在上面程序中如果我們把”static CyclicBarrier c = new CyclicBarrier(2);”中的參數2修改為3的話改程序中的線程Thread-0和main則會一直等待下去,因為CyclicBarrier是讓一組線程到達一個屏障(也可以叫同步點)時被阻塞,直到最后一個線程到達屏障時,屏障才會開門,而這最后一個線程遲遲不來,所以屏障也不會被打開。

CyclicBarrier還提供一個更高級的構造函數CyclicBarrier(int parties, Runnable barrierAction),用于在線程到達屏障時,優先執行barrierAction,方便處理更復雜的業務場景。我們來看一下示例:

public class CyclicBarrierTest { static CyclicBarrier c = new CyclicBarrier(2,new PrioExecut()); public static void main(String[] args) { new Thread(new Runnable() { @Override public void run() {try { c.await();} catch (Exception e) {}System.out.println(Thread.currentThread().getName()+'正在等待...'); } }).start(); try { c.await(); } catch (Exception e) { } System.out.println(Thread.currentThread().getName()+'正在等待...'); System.out.println('人夠了,出發吧 當前有 '+c.getParties()+' 個人參與比賽'); }}class PrioExecut implements Runnable{ @Override public void run() { System.out.println('我會先跑5秒,不管你信不信!'); }}

執行結果為:

我會先跑5秒,不管你信不信!Thread-0正在等待...main正在等待...人夠了,出發吧 當前有 2 個人參與比賽

Process finished with exit code 0

我們可以看到構造方法中的參數:new PrioExecut()中的線程會優先執行。

2.CyclicBarrier的應用場景

CyclicBarrier可以用于多線程計算數據,最后合并計算結果的應用場景。比如在支付業務中,我們可以按照事先劃分好的片區的形式來統計日收支流水,然后根據片區的計算結果,使用Runnable barrierAction來進行匯總這是一個很好的實現。

3.CyclicBarrier和CountDownLatch的區別

在javadoc里面的描述是這樣的:

CountDownLatch: A synchronization aid that allows one or more threads to wait until a set of operations being performed in other threads completes.

CyclicBarrier : A synchronization aid that allows a set of threads to all wait for each other to reach a common barrier point.

根據我的理解:對于CountDownLatch來說,重點是那個“一個線程”, 它在等待其余線程執行完畢他才能執行,而另外那N的線程在把“某個事情”做完之后可以繼續等待,可以終止。比如上文說的跑步的例子,只有5位跑步者同時準備好了,裁判才能下令開始跑步;CyclicBarrier強調的是n個線程,大家相互等待,只要有一個沒完成,所有人都得等著。 CountDownLatch的計數器無法被重置;CyclicBarrier的計數器可以使用reset() 方法重置。所以CyclicBarrier能處理更為復雜的業務場景,比如如果計算發生錯誤,可以重置計數器,并讓線程們重新執行一次。

以上就是java并發編程專題(九)----(JUC)淺析CyclicBarrier的詳細內容,更多關于java juc CyclicBarrier的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产毛片久久| 日本一区中文字幕| 日韩国产在线观看| 一区二区精品| 综合欧美亚洲| 亚洲资源网站| 日本在线观看不卡视频| 视频一区二区欧美| 亚洲精选久久| 91九色综合| 国产色99精品9i| 国产精选一区| 国产欧美88| 国产精品mm| 久久久精品五月天| 99久久久久| 玖玖精品视频| 日韩激情一二三区| 欧美激情aⅴ一区二区三区| 久久三级毛片| 91精品电影| 日韩精品视频网| 国产精品v一区二区三区| 日本黄色精品| 欧美成人精品午夜一区二区| 麻豆mv在线观看| 麻豆亚洲精品| 在线综合亚洲| 日本不卡不码高清免费观看| 久久香蕉网站| 天堂av在线一区| 久久久久伊人| 久久精品主播| 日韩中文字幕1| 69堂免费精品视频在线播放| 亚洲一区日本| 久久美女精品| www.com.cn成人| 日韩中出av| 日韩啪啪电影网| 综合日韩在线| 日韩视频一区| 天堂√中文最新版在线| 狠狠久久婷婷| 欧美激情日韩| 日韩国产欧美在线播放| 国产一区亚洲| 国产不卡精品| 国产精品久久久免费| 亚洲欧美日韩国产一区| 欧美sss在线视频| 久久精品国产在热久久| 日本aⅴ亚洲精品中文乱码| 欧美日韩国产传媒| 国产精品久久观看| 欧美国产专区| 欧美1区二区| 欧美日韩一区二区三区四区在线观看 | 久久99久久人婷婷精品综合| 老牛影视一区二区三区| 亚洲成人精选| 国产精品97| 国产精品美女久久久| 国产婷婷精品| 蜜桃久久av一区| 91久久亚洲| 黄页网站一区| 国产精品腿扒开做爽爽爽挤奶网站| 91精品婷婷色在线观看| 欧美日中文字幕| 性色一区二区| 中文字幕一区二区三区在线视频| 国产色综合网| 日韩一二三区在线观看| 精品福利久久久| 日本а中文在线天堂| 欧美色图国产精品| 日韩制服丝袜先锋影音| 国产调教精品| 日韩成人亚洲| 最近国产精品视频| 日韩国产在线观看一区| 国产91在线精品| 国产女优一区| 国产精品亚洲产品| 亚洲91久久| 日本成人在线网站| 日韩av一级| 国产欧美日韩一级| 久久亚洲在线| 欧美亚洲自偷自偷| av高清不卡| 日韩av网站在线免费观看| 国产精品国产三级国产在线观看| 国产精品7m凸凹视频分类| 国产精品夜夜夜| 伊人久久大香线蕉av不卡| 日韩高清三区| 久久一区二区三区喷水| 国产欧美日韩一区二区三区在线| 成人羞羞在线观看网站| 日韩精品视频在线看| 欧美亚洲激情| 国产高清日韩| 日本一区二区中文字幕| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 日韩在线第七页| 在线看片日韩| 999国产精品视频| 国产欧美久久一区二区三区| 99国产精品自拍| 欧美色图国产精品| 水蜜桃久久夜色精品一区| 国产精品2023| 国产精区一区二区| 日本在线视频一区二区| 视频一区在线视频| 99在线|亚洲一区二区| 久久久久国产精品一区三寸| 欧美日韩1区2区3区| 日韩中文字幕| 日本亚洲最大的色成网站www | 精品国产亚洲一区二区三区| 日韩一区二区三免费高清在线观看| 婷婷亚洲综合| 亚洲性视频h| av一区二区高清| 亚洲婷婷免费| 欧美成人午夜| 久久狠狠婷婷| 久久影院一区| 亚洲精品888| 日韩综合精品| 少妇精品导航| 黄色精品网站| 日韩精品成人在线观看| 婷婷视频一区二区三区| 亚洲97av| 国产精品综合| 国产精品极品国产中出| 欧美黄色精品| 韩国久久久久久| 欧美日韩一二| 亚洲精品第一| 精品一区二区男人吃奶| 日韩电影免费网站| 久久精品国产68国产精品亚洲| 日韩激情一区| 西西人体一区二区| 国产精品一国产精品k频道56| 精品国产一级| 久久高清国产| 精品中文在线| 91成人精品| 国产精品调教视频| 国户精品久久久久久久久久久不卡| 视频一区二区中文字幕| 国产精品s色| 亚洲免费婷婷| 美女尤物国产一区| 亚洲欧美不卡| 激情黄产视频在线免费观看| 国产欧美一区二区三区精品酒店 | 日韩欧美在线中字| 欧美亚洲三级| 99久久精品网| 精品国产中文字幕第一页| 老牛国产精品一区的观看方式| 免费在线亚洲欧美| 日av在线不卡| 91精品国产91久久久久久黑人| 国产精品密蕾丝视频下载| 欧美日韩国产一区精品一区| 精品中文字幕一区二区三区| 蜜臀91精品一区二区三区| 成人午夜国产| 国产精品亲子伦av一区二区三区| 欧美日韩日本国产亚洲在线| 国产一区二区三区四区五区传媒 | 在线亚洲观看| 韩国精品主播一区二区在线观看| 国产精品色婷婷在线观看| 涩涩涩久久久成人精品| 五月天久久网站| 久久免费高清| 91免费精品| 高清日韩中文字幕| 国产精品久久久久久久久久妞妞| 一区二区精彩视频| 免费精品国产的网站免费观看| 精品高清久久| 超级白嫩亚洲国产第一| 你懂的国产精品| 老司机精品在线| 国产一区二区三区四区大秀| 久久av中文| 首页国产精品| 91精品亚洲| 免费日韩av片| 亚洲日韩中文字幕一区|