zoukankan      html  css  js  c++  java
  • 闭锁(CountDownLatch)

    package japan.example.test;
    
    import java.util.concurrent.CountDownLatch;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.TimeUnit;
    
    public class CountDownLatchTest {
    
        public static void main(String[] args) throws Exception {
    
            CountDownLatchTest test = new CountDownLatchTest();
            test.test();
        }
    
        public void test() throws InterruptedException {
            int nthread = 5;
            ExecutorService service = Executors.newFixedThreadPool(nthread);
    
            CountDownLatch latch = new CountDownLatch(nthread);
    
            for (int i = 0; i < nthread; i++) {
                service.execute(new Runner(latch));
            }
    
            latch.await();
    
            service.shutdown();
            while (!service.isTerminated()) {
                try {
                    // 用于等待子线程结束,再继续执行下面的代码
                    service.awaitTermination(5, TimeUnit.SECONDS);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
    
        }
    
    }
    
    class Runner implements Runnable {
    
        CountDownLatch latch;
    
        Runner(CountDownLatch latch) {
            this.latch = latch;
        }
    
        @Override
        public void run() {
            try {
                // dosomething
                System.err.println("say hello!");
            } finally {
                latch.countDown();
            }
        }
    
    }
  • 相关阅读:
    用redis实现分布式锁
    mac下Nginx+lua模块编译安装
    ESXi5 中克隆Linux虚拟主机的网络配置
    DOS命令中的For
    让delphi解析chrome扩展的native应用
    C语言 cgi(3)
    C语言 cgi(2)
    C语言cgi(1)
    c++ input,output
    Array of Objects
  • 原文地址:https://www.cnblogs.com/jpit/p/8444826.html
Copyright © 2011-2022 走看看