JUC并发包下的工具类

2024-01-23 18:58
文章标签 工具 juc 发包

本文主要是介绍JUC并发包下的工具类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、闭锁CountDownLatch

作用:让当前线程等到一组事件发生后再继续执行

举例:比如,运动员和裁判员,裁判员线程需要等到所有的运动员线程到达之后才可以宣布比赛结束

闭锁中几个重要的方法

         (1)构造方法:public CountDownLatch(int count):count【需要等待的线程数】

         (2)public void countDown():线程每调用一次,等待线程的计数器-1(也就是说运动员线程每执行一次,裁判线程计数器-1)

        (3)public void await()throws InterruptedException():调用这个方法的线程会阻塞直到计数器减为0

代码如下:


import java.util.concurrent.CountDownLatch;public class TestCountDownLatch {public static void main(String[] args) {CountDownLatch latch=new CountDownLatch(3);Runnable runnable=new Sport(latch);Thread threadA=new Thread(runnable,"运动员A");Thread threadB=new Thread(runnable,"运动员B");Thread threadC=new Thread(runnable,"运动员C");System.out.println("比赛开始");threadA.start();threadB.start();threadC.start();try {latch.await();} catch (InterruptedException e) {e.printStackTrace();}System.out.println("比赛结束");}static class Sport implements Runnable{CountDownLatch latch;public Sport(CountDownLatch latch){this.latch=latch;}@Overridepublic void run() {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName()+"到达");latch.countDown();}}
}

执行结果:

注意:CountDownLatch的对象,当计数器减为0时,不可恢复,也就是不能再用了

二、循环栅栏CyclicBarrier

作用:若干个线程等待所有的线程都到达同一个状态之后,再恢复执行

举例:比如,开会,已知有5个人参加会议,那么到达的每一个人都需要等待5个人全部都到了这一状态才可以开始开会

几个重要的方法:
         (1)public  CyclicBarrier(int parties)

         (2)public CyclicBarrier(int parties,Runnable barrrierAction)

                    parties:同时等待的线程个数            barrrierAction:恢复执行之前,随机挑选一个线程执行该任务

代码如下:


import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;public class TestCyclicBarrier {public static void main(String[] args) {System.out.println("等待开会");//当所有线程到达barrier状态后,会从所有线程中随机选择一个来执行RunnableCyclicBarrier barrier=new CyclicBarrier(3, new Runnable() {@Overridepublic void run() {System.out.println(Thread.currentThread().getName());}});Runnable task=new Participant(barrier);new Thread(task,"员工A").start();new Thread(task,"员工B").start();new Thread(task,"员工C").start();}
}
class Participant implements Runnable{CyclicBarrier barrier;public Participant(CyclicBarrier barrier){this.barrier=barrier;}@Overridepublic void run() {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName()+"到达");try {barrier.await();} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}System.out.println("开始开会");}
}

运行结果如下:可以看到barrrierAction是在恢复执行之前,随机挑选一个线程执行这个任务

注意:CyclicBarrier的对象的值可以恢复,reset()方法,可以重复使用

 

****闭锁和循环栅栏看起来很类似

                都是阻塞等待其他线程,但是侧重点不同:

                闭锁是只某个线程去等待一组线程结束之后再恢复执行;而循环栅栏是指一组线程都要等到该组线程执行到某个状态之后,再恢复执行

 

三、Exchanger--线程交换器

作用:两两线程配对后交换数据再同时恢复执行,若线程调用Exchanger.exchange(),缓冲区只有一个线程,

则当前线程阻塞,直到有另一个线程调用Exchanger.exchange(),两线程交换数据

举例:密码的验证,信息的交换,都需要进行数据的交换,就以两个人说话为例

代码如下:

import java.util.concurrent.Exchanger;/*** 用于线程间协作的工具类,它提供一个同步点,在这个同步点,两个线程可以交货彼此的数据* 通过exchange交换数据,如果第一个线程先执行了exchange()方法,它会已知等待第二个线程也执行exchange()方法* 当两个线程都到达同步点时,这两个线程就可以交换数据了,将本线程生产出来的数据传递给对方*/
public class TestExchanger {public static void main(String[] args) {Exchanger<String> exchanger=new Exchanger<>();Runnable boy=new boy(exchanger);Runnable girl=new girl(exchanger);new Thread(boy,"Thread-boy").start();new Thread(girl,"Thread-girl").start();}
}
class boy implements Runnable {Exchanger<String> exchanger;public boy(Exchanger exchanger){this.exchanger=exchanger;}@Overridepublic void run() {System.out.println("我是男方");try {String result=exchanger.exchange("男方说的话");System.out.println(Thread.currentThread().getName()+":"+result);} catch (InterruptedException e) {e.printStackTrace();}}
}
class girl implements Runnable{Exchanger<String> exchanger;public girl(Exchanger exchanger){this.exchanger=exchanger;}@Overridepublic void run() {System.out.println("我是女方");try {String result=exchanger.exchange("女方说的话");System.out.println(Thread.currentThread().getName()+":"+result);} catch (InterruptedException e) {e.printStackTrace();}}
}

执行结果如下:可以看到数据进行了交换,双方都接收到了对方的信息数据

这篇关于JUC并发包下的工具类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/637221

相关文章

MobaXterm远程登录工具功能与应用小结

《MobaXterm远程登录工具功能与应用小结》MobaXterm是一款功能强大的远程终端软件,主要支持SSH登录,拥有多种远程协议,实现跨平台访问,它包括多会话管理、本地命令行执行、图形化界面集成和... 目录1. 远程终端软件概述1.1 远程终端软件的定义与用途1.2 远程终端软件的关键特性2. 支持的

Java数字转换工具类NumberUtil的使用

《Java数字转换工具类NumberUtil的使用》NumberUtil是一个功能强大的Java工具类,用于处理数字的各种操作,包括数值运算、格式化、随机数生成和数值判断,下面就来介绍一下Number... 目录一、NumberUtil类概述二、主要功能介绍1. 数值运算2. 格式化3. 数值判断4. 随机

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

Java中基于注解的代码生成工具MapStruct映射使用详解

《Java中基于注解的代码生成工具MapStruct映射使用详解》MapStruct作为一个基于注解的代码生成工具,为我们提供了一种更加优雅、高效的解决方案,本文主要为大家介绍了它的具体使用,感兴趣... 目录介绍优缺点优点缺点核心注解及详细使用语法说明@Mapper@Mapping@Mappings@Co

使用Python实现图片和base64转换工具

《使用Python实现图片和base64转换工具》这篇文章主要为大家详细介绍了如何使用Python中的base64模块编写一个工具,可以实现图片和Base64编码之间的转换,感兴趣的小伙伴可以了解下... 简介使用python的base64模块来实现图片和Base64编码之间的转换。可以将图片转换为Bas

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做