Java詳解多線程協(xié)作作業(yè)之信號(hào)同步
一、信號(hào)同步
多線程很多時(shí)候是協(xié)作作業(yè)。比如4個(gè)線程對電商數(shù)據(jù)分季度統(tǒng)計(jì),統(tǒng)計(jì)完成之后,再匯總。如何知道4個(gè)線程都執(zhí)行完成呢,我們可以使用JDK1.5給我們提供的輔助類CountDownLatch(
減少計(jì)數(shù))、CyclicBarrier(循環(huán)柵欄)、Semaphore(信號(hào)燈)。
二、基于時(shí)間維度
1、CountDownLatch
多少個(gè)協(xié)作線程就初始化CountDownLatch的構(gòu)造參數(shù)是多少。
public static void main(String[] args) throws InterruptedException { final int NUM=6; //定義總數(shù)量; CountDownLatch countDownLatch=new CountDownLatch(NUM); for (int i = 0; i < NUM; i++) { new Thread(()->{ System.out.println(Thread.currentThread().getName()+"線程,已執(zhí)行!"); //減少計(jì)數(shù) countDownLatch.countDown(); },String.valueOf(i+1)).start(); } //等待所有任務(wù)完成 countDownLatch.await(); System.out.println("所有線程任務(wù)已經(jīng)執(zhí)行完成!"); }
2、CyclicBarrier
與減少計(jì)數(shù)類似
public static void main(String[] args) { final int NUM = 6; //定義循環(huán)數(shù)量及循環(huán)完成后的任務(wù)(Runnable接口實(shí)現(xiàn)); CyclicBarrier cyclicBarrier = new CyclicBarrier(NUM, () -> { System.out.println("所有線程任務(wù)已經(jīng)執(zhí)行完成!"); }); for (int i = 0; i < NUM; i++) { new Thread(()->{ System.out.println(Thread.currentThread().getName()+"線程,已執(zhí)行!"); try { //等待點(diǎn)或障礙點(diǎn),等待所有任務(wù)完成, cyclicBarrier.await(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } },String.valueOf(i+1)).start(); } }
三、基于信號(hào)維度
Semaphore,線程與信號(hào)是m:n,其中m>=n。
import java.util.Random; import java.util.concurrent.Semaphore; import java.util.concurrent.TimeUnit; /*信號(hào)燈 * 6個(gè)線程,搶占三個(gè)信號(hào) * */ public class SemaphoreDemo { public static void main(String[] args) { Semaphore semaphore=new Semaphore(3); for (int i = 0; i < 6; i++) { new Thread(()->{ try { //獲取信號(hào) semaphore.acquire(); System.out.println("線程:"+Thread.currentThread().getName()+"----獲取信號(hào)"); int time = new Random().nextInt(5); System.out.println(("線程:"+Thread.currentThread().getName()+"----休眠"+time+"s!")); TimeUnit.SECONDS.sleep(time); } catch (InterruptedException e) { e.printStackTrace(); }finally { // 釋放信號(hào) System.out.println("線程:"+Thread.currentThread().getName()+"---釋放信號(hào)"); semaphore.release(); } },String.valueOf(i+1)).start(); } } }
首先線程4、1、3獲取到信號(hào),線程1釋放信號(hào)后,線程2獲得信號(hào)。線程2、3釋放信號(hào)后,線程5、6獲得信號(hào)。
到此這篇關(guān)于Java詳解多線程協(xié)作作業(yè)之信號(hào)同步的文章就介紹到這了,更多相關(guān)Java信號(hào)同步內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺析java并發(fā)中的Synchronized關(guān)鍵詞
這篇文章主要介紹了java并發(fā)中的Synchronized關(guān)鍵詞,本文通過思路代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02Java List Object[]轉(zhuǎn)換成List T的實(shí)例
這篇文章主要介紹了Java List Object[]轉(zhuǎn)換成List T的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09IDEA中Mybatis的MGB使用逆向工程配置的詳細(xì)教程
這篇文章主要介紹了IDEA中Mybatis的MGB使用逆向工程配置,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09SpringCloud手寫Ribbon實(shí)現(xiàn)負(fù)載均衡
這篇文章主要介紹了SpringCloud手寫Ribbon實(shí)現(xiàn)負(fù)載均衡的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01Spring+SpringMVC+MyBatis深入學(xué)習(xí)及搭建(二)之MyBatis原始Dao開發(fā)和mapper代理開發(fā)
這篇文章主要介紹了Spring+SpringMVC+MyBatis深入學(xué)習(xí)及搭建(二)之MyBatis原始Dao開發(fā)和mapper代理開發(fā),需要的朋友可以參考下2017-05-05Java數(shù)據(jù)結(jié)構(gòu)(線性表)詳解
本文主要介紹了Java數(shù)據(jù)結(jié)構(gòu)(線性表)的相關(guān)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01Java8 實(shí)現(xiàn)stream將對象集合list中抽取屬性集合轉(zhuǎn)化為map或list
這篇文章主要介紹了Java8 實(shí)現(xiàn)stream將對象集合list中抽取屬性集合轉(zhuǎn)化為map或list的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02詳解OpenAPI開發(fā)如何動(dòng)態(tài)的添加接口實(shí)現(xiàn)
這篇文章主要為大家介紹了OpenAPI開發(fā)如何動(dòng)態(tài)的添加接口實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04