Phaser详解

Phaser是一个相对较新且功能强大的同步原语,它于Java 7中引入,用于协调并行任务的执行。与CyclicBarrierCountDownLatch等传统的同步工具相比,Phaser提供了更灵活和更高级的功能,特别是在处理动态和可变的并行任务集合时。

1.Phaser基本概念

Phaser是一个可重用的同步屏障,它允许一组线程互相等待,直到所有线程都到达某个屏障(barrier point)为止。但与CyclicBarrier不同的是,Phaser支持动态调整参与的线程数,并且允许线程在一个phaser阶段完成后注册参与下一个阶段。
每个Phaser对象都有一个整数表示的阶段(phase)计数,每个阶段可以看作是一组并行任务的一个协调点。当所有注册的线程通过调用arrive()arriveAndAwaitAdvance()方法到达一个阶段时,该阶段就会结束,所有等待的线程将被释放以继续执行,同时阶段计数会增加。

2.构造函数和关键方法

构造函数:

  1. Phaser()
    创建一个新的Phaser对象,其初始阶段计数为0,且没有注册的参与者。这通常用于层次结构的Phaser,其中子Phaser会动态地注册到父Phaser
  2. Phaser(int parties)
    创建一个新的Phaser对象,并初始化给定数量的参与者。这里的parties表示在Phaser更改阶段之前,必须通过调用arriveAndAwaitAdvance()arrive()方法的线程数。
  3. Phaser(Phaser parent)
    创建一个新的Phaser对象,并将其关联到给定的父Phaser。子Phaser的终止会影响到父Phaser的终止,但反之则不然。此构造函数创建的Phaser初始时没有注册的参与者。
  4. Phaser(Phaser parent, int parties)
    创建一个新的Phaser对象,它既有父Phaser又有初始注册的参与者数量。这个构造函数结合了前两个构造函数的功能。

关键方法:

  • arrive():表示当前线程已经完成了当前阶段的工作,并减少到达该阶段的线程数。
  • arriveAndAwaitAdvance():与arrive()类似,但它还会使当前线程等待其他线程到达此阶段,然后一起进入下一个阶段。
  • awaitAdvance(int phase):等待直到Phaser的当前阶段改变为给定的phase,或者当前线程被中断。
  • register():在当前阶段增加一个未到达的线程。这允许动态地添加新的参与者。
  • bulkRegister(int parties):一次性注册多个未到达的线程。

3.Phaser的优势

  1. 灵活性:与CyclicBarrier相比,Phaser允许在运行时动态地添加或移除参与者。
  2. 多阶段支持:Phaser支持多个协调点,而不仅仅是单个屏障。
  3. 可重用性:一旦所有线程到达一个阶段,Phaser可以自动地或手动地重置为下一个阶段,而不需要重新创建。

4.使用Phaser实现并行计算

import java.util.concurrent.Phaser;  public class PhaserExample {  public static void main(String[] args) {  final int numberOfTasks = 10;  final Phaser phaser = new Phaser(numberOfTasks); // 创建一个Phaser,初始参与者数量为10  for (int i = 0; i < numberOfTasks; i++) {  final int taskID = i;  new Thread(() -> {  System.out.println("Task " + taskID + " is starting.");  // 模拟计算工作  try {  Thread.sleep((long) (Math.random() * 1000));  } catch (InterruptedException e) {  e.printStackTrace();  }  System.out.println("Task " + taskID + " is finishing.");  phaser.arrive(); // 表示任务完成  }).start();  }  // 等待所有任务完成  phaser.awaitAdvance(phaser.getPhase());  System.out.println("All tasks are complete.");  }  
}

运行结果:

Task 1 is starting.
Task 2 is starting.
Task 0 is starting.
Task 4 is starting.
Task 3 is starting.
Task 5 is starting.
Task 6 is starting.
Task 7 is starting.
Task 8 is starting.
Task 9 is starting.
Task 1 is finishing.
Task 4 is finishing.
Task 2 is finishing.
Task 8 is finishing.
Task 6 is finishing.
Task 3 is finishing.
Task 7 is finishing.
Task 9 is finishing.
Task 0 is finishing.
Task 5 is finishing.
All tasks are complete.

在这个例子中,我们创建了一个包含10个任务的Phaser,每个任务都在它自己的线程中运行。当每个任务完成时,它会通过调用arrive()方法通知Phaser。主线程通过调用awaitAdvance()方法等待所有任务完成。
注意,虽然这个例子使用了固定数量的任务,但Phaser的真正优势在于能够处理动态添加或移除的并行任务。通过调用register()arrive()方法,可以在任何时候增加新的参与者到当前的阶段中。
Phaser是Java并发工具包中一个强大而灵活的组件,它提供了协调并行任务执行的高级机制。在处理复杂的多线程问题时,考虑使用Phaser可以使代码更加简洁且易于管理。

5.总结

Phaser是Java并发工具包中一个强大而灵活的组件,它提供了协调并行任务执行的高级机制。在处理复杂的多线程问题时,考虑使用Phaser可以使代码更加简洁且易于管理

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/614103.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python-基础语法

标识符 第一个字符必须是字母表中字母或下划线 _ 。标识符的其他的部分由字母、数字和下划线组成。标识符对大小写敏感。在 Python 3 中&#xff0c;可以用中文作为变量名&#xff0c;非 ASCII 标识符也是允许的了。 python保留字 保留字即关键字&#xff0c;我们不能把它们用…

MATLAB全局最优搜索函数:GlobalSearch函数

摘要&#xff1a;本文介绍了 GlobalSearch 函数的使用句式&#xff08;一&#xff09;、三个运行案例&#xff08;二&#xff09;、 GlobalSearch 函数的参数设置&#xff08;三&#xff09;、GlobalSearch 注意事项及必要说明&#xff08;五&#xff09;等内容。详细介绍如下&…

超维空间S2无人机使用说明书——11、使用3维激光雷达实现ROS无人机的精准定位

引言&#xff1a;在工程应用中&#xff0c;往往需要在没有GPS信号的情况下实现无人机的资助或者稳定的飞行。实现这个的基础就是定位&#xff0c;有了准确的定位信息&#xff0c;无人机才能稳定的飞行。性比较于视觉定位效果&#xff0c;目前3D雷达相对更加稳定&#xff0c;视觉…

FineBI实战项目一(18):每小时上架商品个数分析开发

点击新建组件&#xff0c;创建每小时上架商品个数组件。 选择线图&#xff0c;拖拽cnt&#xff08;总数&#xff09;到纵轴&#xff0c;拖拽hourStr到横轴。 修改横轴和纵轴的文字。 调节连线样式。 添加组件到仪表板。

【LeetCode】59. 螺旋矩阵II(中等)——代码随想录算法训练营Day02

题目链接&#xff1a;59. 螺旋矩阵II 题目描述 给你一个正整数 n &#xff0c;生成一个包含 1 到 n 所有元素&#xff0c;且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。 示例 1&#xff1a; 输入&#xff1a;n 3 输出&#xff1a;[[1,2,3],[8,9,4],[7,6,5]] 示例 …

攒机到底能省多少钱?

昨天弄好了攒机配置&#xff0c;今天要求配置一些更为实用的配置&#xff0c;只是作为一般办公&#xff0c;单位买进来的计算机都是联想&#xff0c;价格普遍在7000元以上&#xff0c;出于省钱和实用目的&#xff0c;今天搭配了一个组机方案。 上面的配置对付一般办公足够&…

基于JAVA的婚恋交友网站 开源项目

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 会员管理模块2.3 新闻管理模块2.4 相亲大会管理模块2.5 留言管理模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 会员信息表3.2.2 新闻表3.2.3 相亲大会表3.2.4 留言表 四、系统展示五、核心代码5.…

Docker 有什么优势?

Docker作为一种流行的容器化技术&#xff0c;其优势所在可以从多个维度进行详细阐述。 ![&nbsp][nbsp] 统一环境 在容器化技术成熟之前&#xff0c;软件开发过程中环境部署是一个常见的问题&#xff0c; 开发到生产的整个软件交付流程往往受到多个因素的影响。 场景描述…

Magento1.9 浏览器提示该网页无法正常运作,将您重定向的次数过多

不久前部署了一个Magento网站&#xff0c;访问时却直接打不开&#xff1a; 该网页无法正常运作 xxx.com将您重定向的次数过多 若要解决此问题&#xff0c;请尝试清除 Cookie. ERR_TOO_MANY_REDIRECTS 我的网络架构是这样的&#xff1a; 网站部署在Nginx服务器上, 做了加密…

2 快速前端开发

CSS快速入门 1.CSS案例1.1 内容回顾1.2 案例&#xff1a;二级菜单1.2.1 划分区域1.2.2 搭建骨架1.2.3 Logo区域1.2.4 菜单部分 1.3 案例&#xff1a;顶部菜单 二级菜单小结 1.4 案例&#xff1a;推荐区域1.4.1 划分区域1.4.2 搭建骨架1.4.3 案例的实现小结 2. CSS知识点2.1 ho…

登录模块的实现

一.前期的准备工作 1.页面的布局 (1)表单的校验: 利用element-ui提供的文档绑定rules规则后实现校验 (2)跨域的配置 &#xff1a; 利用proxy代理来解决跨域的问题 (3)axios拦截器的配置 两个点:1. 在请求拦截的成功回调中,如果token,因为调用其它的接口需要token才能调取。 在请…

2024.1.11 Kafka 消息队列,shell命令,核心原理

目录 一 . 消息队列 二. Kafka 三 . 启动命令 四 . Kafka的Shell 命令 五 . Kafka的核心原理 1. Topic的分区和副本机制 2 . 消息存储机制 和 查询机制 3. Kafka中生产者数据分发策略 六 . Kafka 之所以具有高速的读写性能&#xff0c;主要有以下几个原因 七. 笔记…

如何让 QTableView控件五颜六色?

要让 QTableView 控件五颜六色&#xff0c;您可以使用 QStandardItemModel 的 setData() 方法为每个单元格设置不同的背景色。以下是一个示例&#xff1a; // 创建数据模型和设置表头略...// 设置单元格背景色 model->setData(model->index(0, 0), QColor(Qt::red), Qt:…

布隆过滤器 应用场景 优势 不足

布隆过滤器是一种空间效率很高的概率型数据结构&#xff0c;主要用于快速判断一个元素是否存在于一个集合中。它的主要应用场景、优势和不足如下&#xff1a; 应用场景 缓存&#xff1a;在缓存系统中&#xff0c;可以利用布隆过滤器快速判断某个数据是否存在于缓存中&#xf…

212. 单词搜索 II(字典树的另一种类型)

大致思路是&#xff1a; 根据words列表建立字典树&#xff0c;其中注意在单词末尾&#xff0c;将原来的isEnd变量换成存储这个单词的变量&#xff0c;方便存储到ans中&#xff0c;另外&#xff0c;字典树的字节点由原来的Trie数组变为hashmap&#xff0c;方便检索字母。 建立…

【AIGC】一组精美动物AI智能画法秘诀

如何使用AI绘画&#xff0c;从以下角度&#xff0c;依据表格内容梳理&#xff0c;表格如下&#xff1a; 外貌特征物种姿势特征描述场景风格技术描述小巧可爱幼小浣熊倚在桌子上具有人形特征中世纪酒馆电影风格照明8k分辨率细节精致毛茸茸手持咖啡杯Jean-Baptiste Monge的风格蓝…

一日难再晨及时当勉励 date

文章目录 Linux shell 获取更改系统时间默认输入显示时区世界协调时格式化日期更多信息 Linux shell 获取更改系统时间 … note:: 时光只解催人老&#xff0c;不信多情&#xff0c;长恨离亭&#xff0c;泪滴春衫酒易醒。 - 晏殊《采桑子时光只解催人老》date命令可以用来打印…

RT-Thread入门笔记4-跑马灯线程实例

RT-Thread操作系统是基于线程调度的多任务系统。 线程状态切换 调度过程是一种完全抢占式的基于优先级的调度算法。 支持8/32/256优先级&#xff0c;其中0表示最高&#xff0c;7/31/255表示最低。最低优先级7/31/255优先级用于空闲线程。 支持以相同优先级运行的线程。 共享时…

232.【2023年华为OD机试真题(C卷)】计算三叉搜索树的高度(JavaPythonC++JS实现)

🚀点击这里可直接跳转到本专栏,可查阅顶置最新的华为OD机试宝典~ 本专栏所有题目均包含优质解题思路,高质量解题代码(Java&Python&C++&JS分别实现),详细代码讲解,助你深入学习,深度掌握! 文章目录 一. 题目-计算三叉搜索树的高度二.解题思路三.题解代码P…

JS 监听浏览器各个标签间的切换-visibilitychange事件介绍

JS 监听浏览器各个标签间的切换 以前看到过一些网页&#xff0c;在标签切换到其它地址时&#xff0c;网页上的标题上会发生变化&#xff0c;一直不知道这个是怎么做的&#xff0c;最近查了一些资料才发现有一个 visibilitychange 事件就可以搞定&#xff0c;这里将介绍一下页面…