成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

我數(shù) 10 下大家一起上

開(kāi)發(fā) 后端
CountDownLatch是一個(gè)同步工具類,用來(lái)協(xié)調(diào)多個(gè)線程之間的同步,或者說(shuō)起到線程之間通信的作用(非互斥)。

 [[423912]]

在日常編碼中,Java 并發(fā)編程可是少不了,試試下面這些并發(fā)編程工具類:

今天先帶領(lǐng)大家重溫學(xué)習(xí) CountDownLatch 這個(gè)牛叉的工具類,肝起。

認(rèn)識(shí) CountDownLatch

CountDownLatch是一個(gè)同步工具類,用來(lái)協(xié)調(diào)多個(gè)線程之間的同步,或者說(shuō)起到線程之間通信的作用(非互斥)。

CountDownLatch 能夠使一個(gè)線程在等待另外一些線程完成各自工作之后,再繼續(xù)執(zhí)行。使用一個(gè)計(jì)數(shù)器進(jìn)行實(shí)現(xiàn)。計(jì)數(shù)器初始值為線程的數(shù)量。當(dāng)每一個(gè)線程完成自己任務(wù)后,計(jì)數(shù)器的值就會(huì)減一。當(dāng)計(jì)數(shù)器的值為0時(shí),表示所有的線程都已經(jīng)完成一些任務(wù),然后在CountDownLatch上等待的線程就可以恢復(fù)執(zhí)行接下來(lái)的任務(wù)。

CountDownLatch 的使用

CountDownLatch類使用起來(lái)非常簡(jiǎn)單。

Class 位于:java.util.concurrent.CountDownLatch

下面簡(jiǎn)單介紹它的構(gòu)造方法和常用方法。

構(gòu)造方法

CountDownLatch只提供了一個(gè)構(gòu)造方法:

  1. // count 為初始計(jì)數(shù)值 
  2. public CountDownLatch(int count) { 
  3.   // …… 

常用方法

//常用方法1:調(diào)用await()方法的線程會(huì)被掛起,它會(huì)等待直到count值為0才繼續(xù)執(zhí)行

  1. //常用方法1:調(diào)用await()方法的線程會(huì)被掛起,它會(huì)等待直到count值為0才繼續(xù)執(zhí)行 
  2. public void await() throws InterruptedException { 
  3.   // …… 
  4. }    
  5.  
  6. // 常用方法2:和await()類似,只不過(guò)等待超時(shí)后count值還沒(méi)變?yōu)?的話就會(huì)繼續(xù)執(zhí)行 
  7. public boolean await(long timeout, TimeUnit unit) throws InterruptedException {  
  8.   // …… 
  9.  
  10. // 常用方法3:將count值減1 
  11. public void countDown() { 
  12.   // …… 
  13. }   

CountDownLatch 的應(yīng)用場(chǎng)景

我們考慮一個(gè)場(chǎng)景:用戶購(gòu)買(mǎi)一個(gè)商品下單成功后,我們會(huì)給用戶發(fā)送各種消息提示用戶『購(gòu)買(mǎi)成功』,比如發(fā)送郵件、微信消息、短信等。所有的消息都發(fā)送成功后,我們?cè)诤笈_(tái)記錄一條消息表示成功。

當(dāng)然我們可以使用單線程去完成,逐個(gè)完成每個(gè)操作,如下圖所示:

但是這樣效率就會(huì)非常低。如何解決單線程效率低的問(wèn)題?當(dāng)然是通過(guò)多線程啦。

使用多線程也會(huì)遇到一個(gè)問(wèn)題,子線程消息還沒(méi)發(fā)送完,主線程可能就已經(jīng)打出『所有的消息都已經(jīng)發(fā)送完畢啦』,這在邏輯上肯定是不對(duì)的。我們期望所有子線程發(fā)完消息主線程才會(huì)打印消息,怎么實(shí)現(xiàn)呢?CountDownLatch就可以解決這一類問(wèn)題。

我們使用代碼實(shí)現(xiàn)上面的需求。

  1. import java.util.concurrent.*; 
  2.  
  3. public class OrderServiceDemo { 
  4.  
  5.     public static void main(String[] args) throws InterruptedException { 
  6.         System.out.println("main thread: Success to place an order"); 
  7.  
  8.         int count = 3; 
  9.         CountDownLatch countDownLatch = new CountDownLatch(count); 
  10.  
  11.         Executor executor = Executors.newFixedThreadPool(count); 
  12.         executor.execute(new MessageTask("email", countDownLatch)); 
  13.         executor.execute(new MessageTask("wechat", countDownLatch)); 
  14.         executor.execute(new MessageTask("sms", countDownLatch)); 
  15.  
  16.         // 主線程阻塞,等待所有子線程發(fā)完消息 
  17.         countDownLatch.await(); 
  18.         // 所有子線程已經(jīng)發(fā)完消息,計(jì)數(shù)器為0,主線程恢復(fù) 
  19.         System.out.println("main thread: all message has been sent"); 
  20.     } 
  21.  
  22.     static class MessageTask implements Runnable { 
  23.         private String messageName; 
  24.         private CountDownLatch countDownLatch; 
  25.  
  26.         public MessageTask(String messageName, CountDownLatch countDownLatch) { 
  27.             this.messageName = messageName; 
  28.             this.countDownLatch = countDownLatch; 
  29.         } 
  30.  
  31.         @Override 
  32.         public void run() { 
  33.             try { 
  34.                 // 線程發(fā)送消息 
  35.                 System.out.println("Send " + messageName); 
  36.                 try { 
  37.                     TimeUnit.SECONDS.sleep(1); 
  38.                 } catch (InterruptedException e) { 
  39.                     e.printStackTrace(); 
  40.                 } 
  41.             } finally { 
  42.                 // 發(fā)完消息計(jì)數(shù)器減 1 
  43.                 countDownLatch.countDown(); 
  44.             } 
  45.         } 
  46.     } 

程序運(yùn)行結(jié)果:

  1. main thread: Success to place an order 
  2. Send email 
  3. Send wechat 
  4. Send sms 
  5. main thread: all message has been sent 

從運(yùn)行結(jié)果可以看到主線程是在所有的子線程發(fā)送完消息后才打印,這符合我們的預(yù)期。

CountDownLatch 的限制

CountDownLatch是一次性的,計(jì)算器的值只能在構(gòu)造方法中初始化一次,之后沒(méi)有任何機(jī)制再次對(duì)其設(shè)置值,當(dāng)CountDownLatch使用完畢后,它不能再次被使用。

 

責(zé)任編輯:武曉燕 來(lái)源: 愛(ài)笑的架構(gòu)師
相關(guān)推薦

2022-11-29 16:35:02

Tetris鴻蒙

2022-12-02 14:20:09

Tetris鴻蒙

2021-04-12 18:03:39

Nginx架構(gòu)負(fù)載

2021-09-11 19:02:34

Hook使用版本

2021-07-02 20:46:06

Go接口動(dòng)態(tài)

2022-12-22 19:04:14

RabbitMQ消息中間件

2011-06-13 13:23:44

投影儀推薦

2009-10-29 16:32:34

Oracle表空間

2021-02-03 09:59:02

鴻蒙HarmonyOS應(yīng)用開(kāi)發(fā)

2012-09-10 13:42:55

PHP項(xiàng)目管理

2009-08-10 18:16:20

C#面試題

2009-09-14 18:24:56

CCNA認(rèn)證考試題庫(kù)

2011-08-05 14:14:12

2021-12-14 09:34:31

丑數(shù)順序指針

2025-01-17 00:00:00

Java隨機(jī)數(shù)服務(wù)

2021-03-10 12:43:06

LDR指令函數(shù)

2021-07-14 08:00:12

Numa架構(gòu)Linux

2019-03-12 09:46:33

程序Windows 10啟動(dòng)

2014-12-15 16:05:54

CocoaChina征文大賽

2018-07-30 16:04:09

ReactJS代碼HTML
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产福利二区 | 日日摸日日碰夜夜爽2015电影 | 欧美综合一区二区三区 | 91免费小视频 | 亚洲顶级毛片 | 欧美11一13sex性hd | 麻豆一区一区三区四区 | 亚洲日本一区二区三区四区 | 精品国产乱码久久久久久影片 | 久久久久久久久久毛片 | 久久久精品一区 | 欧美成年黄网站色视频 | 中文字幕第二十页 | 国产福利精品一区 | 亚洲欧美日韩电影 | 欧美极品在线视频 | 国产一区视频在线 | 精品日韩一区二区 | 九九99靖品 | 色综合99| 免费观看日韩精品 | 久久精品| 免费午夜视频 | 国产一区二区三区高清 | 91免费在线| 国产十日韩十欧美 | 国产成人精品久久二区二区 | 91黄色免费看 | 日本成人在线播放 | 成人午夜看片 | 狠狠伊人 | 国产精品久久久久久久免费大片 | 伊人成人免费视频 | 亚洲欧美视频在线观看 | 成人午夜视频在线观看 | 国产精品美女 | 97操操 | 欧美黄色大片在线观看 | 欧美日韩网站 | 亚洲视频一区二区三区 | www.伊人.com |