Java 多线程协作作业之信号同步


Posted in Java/Android onMay 11, 2022

一、信号同步

多线程很多时候是协作作业。比如4个线程对电商数据分季度统计,统计完成之后,再汇总。如何知道4个线程都执行完成呢,我们可以使用JDK1.5给我们提供的辅助类CountDownLatch(

减少计数)、CyclicBarrier(循环栅栏)、Semaphore(信号灯)。

二、基于时间维度

1、CountDownLatch

多少个协作线程就初始化CountDownLatch的构造参数是多少。

public static void main(String[] args) throws InterruptedException {
        final int NUM=6;
        //定义总数量;
        CountDownLatch countDownLatch=new CountDownLatch(NUM);
        for (int i = 0; i < NUM; i++) {
            new Thread(()->{
                System.out.println(Thread.currentThread().getName()+"线程,已执行!");
                //减少计数
                countDownLatch.countDown();
            },String.valueOf(i+1)).start();
        }
        //等待所有任务完成
        countDownLatch.await();
        System.out.println("所有线程任务已经执行完成!");
    }

Java 多线程协作作业之信号同步

2、CyclicBarrier

与减少计数类似

public static void main(String[] args) {
        final int NUM = 6;
        //定义循环数量及循环完成后的任务(Runnable接口实现);
        CyclicBarrier cyclicBarrier = new CyclicBarrier(NUM, () -> {
            System.out.println("所有线程任务已经执行完成!");
        });
        for (int i = 0; i < NUM; i++) {
            new Thread(()->{
                System.out.println(Thread.currentThread().getName()+"线程,已执行!");
                try {
                    //等待点或障碍点,等待所有任务完成,
                    cyclicBarrier.await();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } catch (BrokenBarrierException e) {
                    e.printStackTrace();
                }
            },String.valueOf(i+1)).start();
        }
    }

Java 多线程协作作业之信号同步

三、基于信号维度

Semaphore,线程与信号是m:n,其中m>=n。

import java.util.Random;
import java.util.concurrent.Semaphore;
import java.util.concurrent.TimeUnit;
/*信号灯
* 6个线程,抢占三个信号
* */
public class SemaphoreDemo {
    public static void main(String[] args) {
        Semaphore semaphore=new Semaphore(3);
        for (int i = 0; i < 6; i++) {
            new Thread(()->{
                try {
                    //获取信号
                    semaphore.acquire();
                    System.out.println("线程:"+Thread.currentThread().getName()+"----获取信号");
                    int time = new Random().nextInt(5);
                    System.out.println(("线程:"+Thread.currentThread().getName()+"----休眠"+time+"s!"));
                    TimeUnit.SECONDS.sleep(time);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }finally {
                //    释放信号
                    System.out.println("线程:"+Thread.currentThread().getName()+"---释放信号");
                    semaphore.release();
                }
            },String.valueOf(i+1)).start();
        }
    }
}

首先线程4、1、3获取到信号,线程1释放信号后,线程2获得信号。线程2、3释放信号后,线程5、6获得信号。

Java 多线程协作作业之信号同步

到此这篇关于Java详解多线程协作作业之信号同步的文章就介绍到这了!


Tags in this post...

Java/Android 相关文章推荐
Java 将PPT幻灯片转为HTML文件的实现思路
Jun 11 Java/Android
Java中多线程下载图片并压缩能提高效率吗
Jul 01 Java/Android
解决Jenkins集成SonarQube遇到的报错问题
Jul 15 Java/Android
Java中CyclicBarrier和CountDownLatch的用法与区别
Aug 23 Java/Android
Java网络编程之UDP实现原理解析
Sep 04 Java/Android
SpringBoot+Vue+JWT的前后端分离登录认证详细步骤
Sep 25 Java/Android
Java实现房屋出租系统详解
Oct 05 Java/Android
Eclipse+Java+Swing+Mysql实现电影购票系统(详细代码)
Jan 18 Java/Android
java objectUtils 使用可能会出现的问题
Feb 28 Java/Android
详解Flutter网络请求Dio库的使用及封装
Apr 14 Java/Android
SpringBoot项目部署到阿里云服务器的实现步骤
Jun 28 Java/Android
SpringBoot Http远程调用的方法
Aug 14 Java/Android
Java 数组的使用
May 11 #Java/Android
Java Spring Lifecycle的使用
May 06 #Java/Android
java开发双人五子棋游戏
解决Springboot PostMapping无法获取数据的问题
May 06 #Java/Android
java版 联机五子棋游戏
Java版 简易五子棋小游戏
java版 简单三子棋游戏
May 04 #Java/Android
You might like
php操作excel文件 基于phpexcel
2010/07/02 PHP
smarty简单分页的实现方法
2014/10/27 PHP
PHP5中使用mysqli的prepare操作数据库的介绍
2019/03/18 PHP
基于jquery的direction图片渐变动画效果
2010/05/24 Javascript
Google AJAX 搜索 API实现代码
2010/11/17 Javascript
JavaScript对象创建及继承原理实例解剖
2013/02/28 Javascript
多种方式实现JS调用后台方法进行数据交互
2013/08/20 Javascript
js中浮点型运算BUG的解决方法说明
2014/01/06 Javascript
jQuery构造函数init参数分析续
2015/05/13 Javascript
JavaScript判断FileUpload控件上传文件类型
2015/09/28 Javascript
JS修改地址栏参数实例代码
2016/06/14 Javascript
jQuery EasyUI中的日期控件DateBox修改方法
2016/11/09 Javascript
JS中位置与大小的获取方法
2016/11/22 Javascript
JS中BOM相关知识点总结(必看篇)
2016/11/22 Javascript
BootStrap3中模态对话框的使用
2017/01/06 Javascript
BootStrap实现鼠标悬停下拉列表功能
2017/02/17 Javascript
微信小程序 template模板详解及实例代码
2017/03/09 Javascript
vue.js的手脚架vue-cli项目搭建的步骤
2017/08/30 Javascript
三分钟学会用ES7中的Async/Await进行异步编程
2018/06/14 Javascript
解决PyCharm中光标变粗的问题
2017/08/05 Python
NumPy 数学函数及代数运算的实现代码
2018/07/18 Python
Python qrcode 生成一个二维码的实例详解
2020/02/12 Python
Python中的__init__作用是什么
2020/06/09 Python
带你学习Python如何实现回归树模型
2020/07/16 Python
纯CSS实现设置半个字符的样式
2014/07/03 HTML / CSS
html5实现图片转圈的动画效果——让页面动起来
2017/10/16 HTML / CSS
HTML5实现移动端复制功能
2018/04/19 HTML / CSS
Derek Rose官网:英国高档睡衣、家居服和内衣品牌
2020/01/18 全球购物
应届生财务会计求职信
2013/11/05 职场文书
幼儿园开学家长寄语
2014/01/19 职场文书
寄语十八大感言
2014/02/07 职场文书
音乐教师求职信
2014/06/28 职场文书
私人委托书格式
2014/09/10 职场文书
新员工实习期个人工作总结
2015/10/15 职场文书
MySQL令人大跌眼镜的隐式转换
2021/08/23 MySQL
二维码条形码生成的JavaScript脚本库
2022/07/07 Javascript