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 相关文章推荐
如何解决springcloud feign 首次调用100%失败的问题
Jun 23 Java/Android
IDEA使用SpringAssistant插件创建SpringCloud项目
Jun 23 Java/Android
mybatis 获取无数据的字段不显示的问题
Jul 15 Java/Android
Java spring单点登录系统
Sep 04 Java/Android
利用Sharding-Jdbc进行分库分表的操作代码
Jan 22 Java/Android
JVM之方法返回地址详解
Feb 28 Java/Android
解析探秘fescar分布式事务实现原理
Feb 28 Java/Android
Java中Quartz高可用定时任务快速入门
Apr 03 Java/Android
MyBatis配置文件解析与MyBatis实例演示
Apr 07 Java/Android
详细介绍Java中的CyclicBarrier
Apr 13 Java/Android
Ubuntu18.04下QT开发Android无法连接设备问题解决实现
Jun 01 Java/Android
Springboot集成kafka高级应用实战分享
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若干单维数组遍历方法的比较
2011/09/20 PHP
PHP数据库链接类(PDO+Access)实例分享
2013/12/05 PHP
php读取文件内容的方法汇总
2015/01/24 PHP
php解析xml方法实例详解
2015/05/12 PHP
PHP Opcache安装和配置方法介绍
2015/05/28 PHP
Smarty3配置及入门语法
2017/02/22 PHP
用js判断页面刷新或关闭的方法(onbeforeunload与onunload事件)
2012/06/22 Javascript
js中数组Array的一些常用方法总结
2013/08/12 Javascript
javascript eval(func())使用示例
2013/12/05 Javascript
jQuery处理图片加载失败的常用方法
2015/06/08 Javascript
jQuery实现仿百度首页滑动伸缩展开的添加服务效果代码
2015/09/09 Javascript
BootStrap智能表单实战系列(八)表单配置json详解
2016/06/13 Javascript
AngularJs Dependency Injection(DI,依赖注入)
2016/09/02 Javascript
Vue.js每天必学之内部响应式原理探究
2016/09/07 Javascript
Vue.js项目模板搭建图文教程
2017/09/20 Javascript
JavaScript实现精美个性导航栏筋斗云效果
2017/10/29 Javascript
swiper在angularjs中使用循环轮播失效的解决方法
2018/09/27 Javascript
Vue.js中 v-model 指令的修饰符详解
2018/12/03 Javascript
vue中v-for通过动态绑定class实现触发效果
2018/12/06 Javascript
详解nodejs解压版安装和配置(带有搭建前端项目脚手架)
2018/12/06 NodeJs
TypeScript高级用法的知识点汇总
2019/12/17 Javascript
[55:48]VGJ.S vs TNC Supermajor 败者组 BO3 第二场 6.6
2018/06/07 DOTA
10种检测Python程序运行时间、CPU和内存占用的方法
2015/04/01 Python
python中__slots__用法实例
2015/06/04 Python
使用python实现rsa算法代码
2016/02/17 Python
python3+PyQt5实现文档打印功能
2018/04/24 Python
django model 条件过滤 queryset.filter(**condtions)用法详解
2020/05/20 Python
娇韵诗法国官网:Clarins法国
2019/01/29 全球购物
阿联酋航空丹麦官方网站:Emirates DK
2019/08/25 全球购物
C#中类(class)与结构(struct)的异同
2013/11/03 面试题
师范生求职自荐信
2014/06/14 职场文书
以幸福为主题的活动方案
2014/08/22 职场文书
2015年元旦晚会活动总结(学生会)
2014/11/28 职场文书
2015暑期社会实践个人总结
2015/07/13 职场文书
Go标准容器之Ring的使用说明
2021/05/05 Golang
MongoDB数据库常用的10条操作命令
2021/06/18 MongoDB