zoukankan      html  css  js  c++  java
  • Java线程--CyclicBarrier使用

    原创:转载需注明原创地址 https://www.cnblogs.com/fanerwei222/p/11867687.html

    Java线程--CyclicBarrier使用, 代码里头有详细注释:

    public static void main(String[] args) {
            /**
             * 可循环使用的栅栏
             * parties表示需要多少个线程同时执行, 相当于一个起跑线
             * 2代表2个线程必须在 await()方法的地方都暂停一下, 等其他人到齐了一起执行
             * 第二个参数代表新建一个线程在所有等待的线程方法之前执行
             */
            CyclicBarrier cyclicBarrier = new CyclicBarrier(2, new Runnable() {
                @Override
                public void run() {
                    System.out.println("先执行这个方法!");
                }
            });
            ExecutorService service1 = Executors.newSingleThreadExecutor();
            service1.execute(new Runnable() {
                @Override
                public void run() {
                    try {
                        Thread.sleep(3000);
                        /**
                         * 设定一个起跑点 , 所有设置了await()方法的线程都必须等到这个时候开始执行
                         * 不能抢跑
                         */
                        cyclicBarrier.await();
                        System.out.println(new Date());
                    } catch (InterruptedException | BrokenBarrierException e) {
                        e.printStackTrace();
                    }
                    System.out.println("子线程:"+Thread.currentThread().getName()+"执行");
                }
            });
            service1.shutdown();
    
            ExecutorService service2 = Executors.newSingleThreadExecutor();
            service2.execute(new Runnable() {
                @Override
                public void run() {
                    try {
                        Thread.sleep(3000);
                        /**
                         * 设定一个起跑点 , 所有设置了await()方法的线程都必须等到这个时候开始执行
                         * 不能抢跑
                         */
                        cyclicBarrier.await();
                        System.out.println(new Date());
                    } catch (InterruptedException | BrokenBarrierException e) {
                        e.printStackTrace();
                    }
                    System.out.println("子线程:"+Thread.currentThread().getName()+"执行");
                }
            });
            service2.shutdown();
        }

    打印如下;

    先执行这个方法!
    Fri Nov 15 16:51:14 CST 2019
    Fri Nov 15 16:51:14 CST 2019
    子线程:pool-1-thread-1执行
    子线程:pool-2-thread-1执行
  • 相关阅读:
    微信开放平台(公众号第三方平台) -- 全网发布
    SQL 邮件配置篇
    让BI告诉你:圣诞老人去哪了?
    锁定和行版本控制
    数据库质疑修复总结(转)
    抢救损坏数据库中的数据
    将 PAGE_VERIFY 数据库选项设置为 CHECKSUM
    replicate复制函数
    @@IDENTITY与SCOPE_IDENTITY()
    RESTORE DATABASE的standby选项
  • 原文地址:https://www.cnblogs.com/fanerwei222/p/11867687.html
Copyright © 2011-2022 走看看