日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

并发工具类(一)等待多线程完成的CountDownLatch

發布時間:2024/1/17 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 并发工具类(一)等待多线程完成的CountDownLatch 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

簡介

CountDownLatch 允許一個或多個線程等待其他線程完成操作。

應用場景

假如有這樣一個需求,當我們需要解析一個Excel里多個sheet的數據時,可以考慮使用多線程,每個線程解析一個sheet里的數據,等到所有的sheet都解析完之后,程序需要提示解析完成。在這個需求中,要實現主線程等待所有線程完成sheet的解析操作,最簡單的做法是使用join。代碼如下:

01public?class?JoinCountDownLatchTest {
02?
03????public?static?void?main(String[] args)?throws?InterruptedException {
04????????Thread parser1 =?new?Thread(new?Runnable() {
05????????????@Override
06????????????public?void?run() {
07????????????}
08????????});
09?
10????????Thread parser2 =?new?Thread(new?Runnable() {
11????????????@Override
12????????????public?void?run() {
13????????????????System.out.println("parser2 finish");
14????????????}
15????????});
16?
17????????parser1.start();
18????????parser2.start();
19????????parser1.join();
20????????parser2.join();
21????????System.out.println("all parser finish");
22????}
23?
24}

join用于讓當前執行線程等待join線程執行結束。其實現原理是不停檢查join線程是否存活,如果join線程存活則讓當前線程永遠wait,代碼片段如下,wait(0)表示永遠等待下去。

1while?(isAlive()) {
2?wait(0);
3}

直到join線程中止后,線程的this.notifyAll會被調用,調用notifyAll是在JVM里實現的,所以JDK里看不到,有興趣的同學可以看看JVM源碼。JDK不推薦在線程實例上使用wait,notify和notifyAll方法。

而在JDK1.5之后的并發包中提供的CountDownLatch也可以實現join的這個功能,并且比join的功能更多。

01<pre>public?class?CountDownLatchTest {
02?
03????static?CountDownLatch c =?new?CountDownLatch(2);
04?
05????public?static?void?main(String[] args)?throws?InterruptedException {
06????????new?Thread(new?Runnable() {
07????????????@Override
08????????????public?void?run() {
09????????????????System.out.println(1);
10????????????????c.countDown();
11????????????????System.out.println(2);
12????????????????c.countDown();
13????????????}
14????????}).start();
15?
16????????c.await();
17????????System.out.println("3");
18????}
19?
20}

CountDownLatch的構造函數接收一個int類型的參數作為計數器,如果你想等待N個點完成,這里就傳入N。

當我們調用一次CountDownLatch的countDown方法時,N就會減1,CountDownLatch的await會阻塞當前線程,直到N變成零。由于countDown方法可以用在任何地方,所以這里說的N個點,可以是N個線程,也可以是1個線程里的N個執行步驟。用在多個線程時,你只需要把這個CountDownLatch的引用傳遞到線程里。

其他方法

如果有某個解析sheet的線程處理的比較慢,我們不可能讓主線程一直等待,所以我們可以使用另外一個帶指定時間的await方法,await(long time, TimeUnit unit): 這個方法等待特定時間后,就會不再阻塞當前線程。join也有類似的方法。

注意:計數器必須大于等于0,只是等于0時候,計數器就是零,調用await方法時不會阻塞當前線程。CountDownLatch不可能重新初始化或者修改CountDownLatch對象的內部計數器的值。一個線程調用countDown方法 happen-before 另外一個線程調用await方法。

原創文章,轉載請注明:?轉載自并發編程網 – ifeve.com本文鏈接地址:?并發工具類(一)等待多線程完成的CountDownLatch

總結

以上是生活随笔為你收集整理的并发工具类(一)等待多线程完成的CountDownLatch的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。