多线程同步计数器CountDownLatch,CyclicBarrier,Semaphore

本文详细介绍了Java中用于多线程同步的三个工具类:CountDownLatch、CyclicBarrier和Semaphore。CountDownLatch允许一个或多个线程等待其他线程完成操作,CyclicBarrier则能让一组线程在达到屏障后同步执行,并可重用。Semaphore用于控制同时访问特定资源的线程数量。它们各自有不同的应用场景,如CountDownLatch适合一个线程等待多个线程,CyclicBarrier适合多线程同步到同一点,而Semaphore则适用于限制并发访问的资源数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

系列文章目录


文章目录


前言

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。
在这里插入图片描述


CountDownLatch
CountDownLatch是一个同步工具类,它允许一个或多个线程等待其他线程一系列操作的完成。

A synchronization aid that allows one or more threads to wait until a set of operations being performed in other threads completes.

我们来看两个示例

@Test
public void CountDownLatchTest1() throws Exception {
   
    // 这里只有一个计数器,子线程都要等待主线程释放这个计数器才会开始执行,子任务等核心任务
    CountDownLatch countDownLatch = new CountDownLatch(1);
    for (int i = 1; i <= 3; i++) {
   
        new Thread(() -> {
   
            System.out.println(Thread.currentThread().getName() + "准备好了");
            try {
   
                countDownLatch.await();
            } catch (InterruptedException e) {
   
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName() + "开始奔跑");
        }, String.valueOf(i) + "号运动员\t").start();
    }
    System.out.println("运动员们进场");
    //睡眠,保证所有子线程创建完毕都进入run方法,执行await()方法
    Thread.sleep(500);
    System.out
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java毕设王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值