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

相关文章

基于Python打造一个全能文本处理工具

《基于Python打造一个全能文本处理工具》:本文主要介绍一个基于Python+Tkinter开发的全功能本地化文本处理工具,它不仅具备基础的格式转换功能,更集成了中文特色处理等实用功能,有需要的... 目录1. 概述:当文本处理遇上python图形界面2. 功能全景图:六大核心模块解析3.运行效果4. 相

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

jvm调优常用命令行工具详解

《jvm调优常用命令行工具详解》:本文主要介绍jvm调优常用命令行工具的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一 jinfo命令查看参数1.1 查看jvm参数二 jstack命令2.1 查看现场堆栈信息三 jstat 实时查看堆内存,gc情况3.1