多线程辅助类CountDownLatch / CyclicBarrier / Semaphore简单入门使用

本文介绍了Java并发控制的三种工具:CountDownLatch、CyclicBarrier和Semaphore。CountDownLatch用于线程同步,等待所有线程完成任务;CyclicBarrier则在固定数量的线程到达屏障后执行特定操作;Semaphore作为信号量,控制同时访问特定资源的线程数量。示例代码展示了它们在实际场景中的应用。
摘要由CSDN通过智能技术生成
  • CountDownLatch就是一个计数器,在创建的时候会传入一个初始值,通过countDown()使计数减一,如果调用了await()方法,只有当计数为0时才会放行

    public static void main(String[] args) {
        CountDownLatch countDownLatch = new CountDownLatch(5);
        for(int i = 1; i <= 5; i++){
            new Thread(new Runnable() {
                @Override
                public void run() {
                    System.out.println(Thread.currentThread().getName() + "离开教室");
                    countDownLatch.countDown();
                }
            }, "同学" + i).start();
        }
    
        try {
            countDownLatch.await();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("所有同学离开教师,班长锁门");
    }
    
  • CyclicBarrier:集齐七颗龙珠即可召唤神龙

    public static void main(String[] args) {
        CyclicBarrier cyclicBarrier = new CyclicBarrier(7, new Runnable() {
            @Override
            public void run() {
                System.out.println("召唤神龙");
            }
        });
        for(int i = 1; i <= 7; i++){
            new Thread(() -> {
                System.out.println(Thread.currentThread().getName() + "已经找到");
                try {
                    cyclicBarrier.await();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } catch (BrokenBarrierException e) {
                    e.printStackTrace();
                }
            }, "龙珠" + i).start();
        }
    }
    
  • Semaphore:信号量,+1-1操作。比如你想吃饭就得有筷子(acquire()),要是没筷子只能等别人吃完腾出筷子(release())。

    public static void main(String[] args) {
        //实现两个线程按序打印
        //定义两个信号量
        Semaphore s1 = new Semaphore(1);
        Semaphore s2 = new Semaphore(0);
        //
        new Thread(() -> {
            for(int i = 1; i <= 3; i++){
                try {
                    s1.acquire();
                    System.out.println("线程1");
                    s2.release();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
    
            }
        }).start();
    
        new Thread(() -> {
            for(int i = 1; i <= 3; i++){
                try {
                    s2.acquire();
                    System.out.println("线程2");
                    s1.release();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
    
            }
        }).start();
    
    }
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值