三种常用的辅助工具类

CountDownLatch

image-20220417090606886

  • 是一个执行减法操作的辅助计数器
//计数器
public class CountDownLatchTest {
    public static void main(String[] args) throws InterruptedException {
        //总数是六,必须在执行任务时再使用
        CountDownLatch countDownLatch = new CountDownLatch(6);
        for (int i = 0; i <=6 ; i++) {
            new Thread(()->{
                System.out.println(Thread.currentThread().getName()+" 开门");
                countDownLatch.countDown(); //执行-1操作
            },String.valueOf(i)).start();
        }
        countDownLatch.await();//等待计数器归零,再执行向下操作
        System.out.println("关门");
    }
}

CyclicBarrier

image-20220417091441246

//加法计数器
public class CyclicBarrierTest {
    public static void main(String[] args) {
        CyclicBarrier cyclicBarrier = new CyclicBarrier(6,()->{
            System.out.println("线程执行完毕");
        });
        for (int i = 0; i <=6 ; i++) {
            final  int temp=i;
            new Thread(()->{ //lambda表达式不能直接获取for循环中的变量,需要通过final类型转换
                System.out.println(Thread.currentThread().getName()+"线程执行了"+temp);
                try {
                    cyclicBarrier.await();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } catch (BrokenBarrierException e) {
                    e.printStackTrace();
                }
            },String.valueOf(i)).start();
        }
    }
}

Semaphore

image-20220417092652705

//运行许可
public class SemaphoreTest {
    public static void main(String[] args) {
        //线程数量:抽象的看成停车位
        Semaphore semaphore = new Semaphore(3); //相当于存在三个停车位
        for (int i = 0; i <=6 ; i++) {
            new Thread(()->{
                try {
                    semaphore.acquire();//获得,假设线程已满,会等待其他线程被释放为止
                    System.out.println(Thread.currentThread().getName()+"抢到了车位");
                    TimeUnit.SECONDS.sleep(2);//线程休眠两秒
                    System.out.println(Thread.currentThread().getName()+"离开了车位");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }finally{
                    semaphore.release(); //释放线程,会将当前的释放量+1,然后唤醒等待
                }
            },String.valueOf(i)).start();
        }
    }
}

作用:

  • 多个共享资源互斥使用
  • 并发限流,控制最大线程数

原文地址:http://www.cnblogs.com/wfy-studying/p/16811740.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性