Java一分钟之-并发编程:线程间通信(Phaser, CyclicBarrier, Semaphore)

本文涉及的产品
实时计算 Flink 版,5000CU*H 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
大数据开发治理平台 DataWorks,不限时长
简介: 【5月更文挑战第19天】Java并发编程中,Phaser、CyclicBarrier和Semaphore是三种强大的同步工具。Phaser用于阶段性任务协调,支持动态注册;CyclicBarrier允许线程同步执行,适合循环任务;Semaphore控制资源访问线程数,常用于限流和资源池管理。了解其使用场景、常见问题及避免策略,结合代码示例,能有效提升并发程序效率。注意异常处理和资源管理,以防止并发问题。

在Java并发编程中,线程间的协作与通信是实现复杂并发逻辑的关键。Phaser, CyclicBarrier, 和 Semaphore 是Java并发包提供的强大工具,它们分别适用于不同的同步需求。本文将深入浅出地介绍这三个组件的使用场景、常见问题及避免策略,并附上代码示例。
image.png

1. Phaser - 阶段性任务协调器

介绍

Phaser 是一个灵活的同步屏障,支持动态注册和取消注册参与者,适用于有多个阶段的任务执行流程。

常见问题与避免策略

  • 问题:过度依赖动态注册,导致阶段结束条件难以预测。
  • 避免:明确每个阶段的预期参与者数量,适时使用arriveAndDeregister方法。

示例

import java.util.concurrent.Phaser;

public class PhaserDemo {
   
   
    public static void main(String[] args) {
   
   
        Phaser phaser = new Phaser(1); // 初始参与者为1(主线程)

        for (int i = 0; i < 3; i++) {
   
   
            new Thread(() -> {
   
   
                System.out.println(Thread.currentThread().getName() + " arrived.");
                phaser.arriveAndAwaitAdvance(); // 到达并等待所有到达
                System.out.println(Thread.currentThread().getName() + " continuing.");
            }, "Thread-" + (i+1)).start();
        }

        phaser.arriveAndDeregister(); // 主线程到达并注销
    }
}

2. CyclicBarrier - 循环屏障

介绍

CyclicBarrier 允许一组线程相互等待,直到达到某个屏障点后一起继续执行。它支持重置和重复使用,适用于循环执行的任务。

常见问题与避免策略

  • 问题:忘记处理BrokenBarrierException,导致程序意外终止。
  • 避免:在run()方法中捕获并适当处理此异常。

示例

import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;

public class CyclicBarrierDemo {
   
   
    public static void main(String[] args) {
   
   
        int parties = 3;
        CyclicBarrier barrier = new CyclicBarrier(parties, () -> System.out.println("All threads reached the barrier."));

        for (int i = 0; i < parties; i++) {
   
   
            new Thread(() -> {
   
   
                try {
   
   
                    System.out.println(Thread.currentThread().getName() + " is waiting on barrier.");
                    barrier.await(); // 等待所有线程到达
                    System.out.println(Thread.currentThread().getName() + " continued.");
                } catch (InterruptedException | BrokenBarrierException e) {
   
   
                    e.printStackTrace();
                }
            }, "Thread-" + (i+1)).start();
        }
    }
}

3. Semaphore - 信号量

介绍

Semaphore 是一种计数信号量,用于控制同时访问特定资源的线程数量,常用于限流和资源池管理。

常见问题与避免策略

  • 问题:未正确释放信号量,导致资源泄露。
  • 避免:确保acquirerelease成对出现,即使在异常情况下也要释放。

示例

import java.util.concurrent.Semaphore;

public class SemaphoreDemo {
   
   
    public static void main(String[] args) {
   
   
        Semaphore semaphore = new Semaphore(2); // 允许两个线程同时访问

        for (int i = 0; i < 5; i++) {
   
   
            new Thread(() -> {
   
   
                try {
   
   
                    semaphore.acquire(); // 获取许可
                    System.out.println(Thread.currentThread().getName() + " entered the critical section.");
                    Thread.sleep(1000);
                    System.out.println(Thread.currentThread().getName() + " leaving the critical section.");
                } catch (InterruptedException e) {
   
   
                    Thread.currentThread().interrupt();
                } finally {
   
   
                    semaphore.release(); // 释放许可
                }
            }, "Thread-" + (i+1)).start();
        }
    }
}

总结而言,Phaser, CyclicBarrier, 和 Semaphore 分别提供了不同维度的线程间通信和同步机制。理解它们的特性和正确使用,是实现高效并发程序的关键。在实际应用中,应根据具体场景选择合适的工具,并注意异常处理和资源管理,以避免常见的并发陷阱。

目录
相关文章
|
1天前
|
数据挖掘 调度 开发者
Python并发编程的艺术:掌握线程、进程与协程的同步技巧
并发编程在Python中涵盖线程、进程和协程,用于优化IO操作和响应速度。`threading`模块支持线程,`multiprocessing`处理进程,而`asyncio`则用于协程。线程通过Lock和Condition Objects同步,进程使用Queue和Pipe通信。协程利用异步事件循环避免上下文切换。了解并发模型及同步技术是提升Python应用性能的关键。
|
2天前
|
Java 开发者 计算机视觉
探索Python中的并发编程:线程与协程
本文将深入探讨Python中的并发编程,重点比较线程和协程的工作机制、优缺点及其适用场景,帮助开发者在实际项目中做出更明智的选择。
|
3天前
|
存储 JSON 算法
Python中的并发编程(4)多线程发送网络请求
Python中的并发编程(4)多线程发送网络请求
|
3天前
|
Java Python
Python中的并发编程(3)线程池、锁
Python中的并发编程(3)线程池、锁
|
3天前
|
并行计算 Python
Python中的并发编程(2)线程的实现
Python中的并发编程(2)线程的实现
Python中的并发编程(2)线程的实现
|
4天前
|
Java
Java 中 CountDownLatch 和 CyclicBarrier 有什么不同?
Java 中 CountDownLatch 和 CyclicBarrier 有什么不同?v
9 0
|
5天前
|
API
java-多线程-CountDownLatch(闭锁) CyclicBarrier(栅栏) Semaphore(信号量)-
java-多线程-CountDownLatch(闭锁) CyclicBarrier(栅栏) Semaphore(信号量)-
10 1
|
6天前
|
存储 安全 Java
Java并发基础-线程间通信
Java并发基础-线程间通信
6 0
|
6天前
|
Python
并发编程,Python让你轻松驾驭多线程与异步IO!
【6月更文挑战第12天】本文探讨了Python中的并发编程,包括多线程和异步IO。通过`threading`模块展示了多线程编程,创建并运行多个线程以并发执行任务。同时,使用`asyncio`库演示了异步IO编程,允许在单线程中高效处理多个IO操作。两个示例代码详细解释了如何在Python中实现并发,展现了其在提升程序性能和响应速度方面的潜力。
|
13天前
|
存储 并行计算 Java
Java8中JUC包同步工具类深度解析(Semaphore,CountDownLatch,CyclicBarrier,Phaser)
Java8中JUC包同步工具类深度解析(Semaphore,CountDownLatch,CyclicBarrier,Phaser)
14 2