CountDownLatch 多线程,等待所有线程结束
2017-10-20 13:53
375 查看
CountDownLatch,一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。
主要方法
public CountDownLatch(int count);
构造方法参数指定了计数的次数
public void countDown();
当前线程调用此方法,则计数减一
public void await() throws InterruptedException
调用此方法会一直阻塞当前线程,直到计时器的值为0
主要方法
public CountDownLatch(int count);
构造方法参数指定了计数的次数
public void countDown();
当前线程调用此方法,则计数减一
public void await() throws InterruptedException
调用此方法会一直阻塞当前线程,直到计时器的值为0
public class CountDownLatchDemo { final static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); public static void main(String[] args) throws InterruptedException { CountDownLatch latch = new CountDownLatch(2);// 两个工人的协作 Worker worker1 = new Worker("zhang san", 5000, latch); Worker worker2 = new Worker("li si", 8000, latch); worker1.start();// worker2.start();// latch.await();// 等待所有工人完成工作 System.out.println("all work done at " + sdf.format(new Date())); } static class Worker extends Thread { String workerName; int workTime; CountDownLatch latch; public Worker(String workerName, int workTime, CountDownLatch latch) { this.workerName = workerName; this.workTime = workTime; this.latch = latch; } public void run() { System.out.println("Worker " + workerName + " do work begin at " + sdf.format(new Date())); try { Thread.sleep(workTime); } catch (InterruptedException e) { e.printStackTrace(); } finally { latch.countDown(); } System.out.println("Worker " + workerName + " do work complete at " + sdf.format(new Date())); } } }
相关文章推荐
- Java:多线程等待所有线程结束(CountDownLatch/CyclicBarrier) .
- Java:多线程等待所有线程结束(CountDownLatch/CyclicBarrier)
- Java:多线程等待所有线程结束(CountDownLatch/CyclicBarrier) .
- CountDownLatch实现主线程等待所有子线程运行结束后再继续执行的实现
- Java:多线程等待所有线程结束(CountDownLatch/CyclicBarrier)
- Java多线程等待所有线程结束(CountDownLatch/CyclicBarrier)
- C# 多线程的等待所有线程结束 用 ManualResetEvent 控制
- Java:多线程等待所有线程结束(CountDownLatch/CyclicBarrier) .
- 多线程中主线程等待所有子线程执行完再继续执行的解决方法
- Java多线程--主线程等待所有子线程执行完毕
- java中等待所有线程都执行结束
- .Net最简单的创建多线程主线程等待所有线程执行完成的例子
- Java多线程--让主线程等待所有子线程执行完毕在执行
- 主线程等待子线程结束(多线程结束标识)
- 利用ThreadGroup等待所有线程执行结束
- Java中等待所有线程都执行结束
- Java多线程、主线程等待所有子线程执行完毕、共享资源
- java中主线程等待所有子线程结束
- 编写多线程代码时,启动线程后等待线程结束方法
- Java多线程--让主线程等待所有子线程执行完毕(转)