CountDownLatch,它是一种计数器的方式保证线程同步;它不去控制多个线程之间的前后关系,只保证某一线程能够在这些子线程执行完之后再执行。
CountDownLatch类似于计数器的方式,用于等待一个或多个线程执行完操作开始自身代码的执行。
其构造函数接收一个int类型的整数作为计数器而使用,例如如果想等待N个线程执行完毕就传入N,当每调用一次countDown函数,表示某一个线程执行完毕。实际上,这个N并不是与线程绑定,也就是说并不是一定和线程的数量一致,只需要countDown函数执行N次,当前等待的线程就会开始执行。
下面列出具体代码
public class CountDownLatchTest { static CountDownLatch countDownLatch = new CountDownLatch(2); public static void main(String[] args) { new Thread(new Runnable() { @Override public void run() { SleepUtils.second(2); System.out.println("1"); countDownLatch.countDown(); } }).start(); new Thread(new Runnable() { @Override public void run() { SleepUtils.second(4); System.out.println("2"); countDownLatch.countDown(); } }).start(); try { // 主线程开始等待 countDownLatch.await(); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("3"); } }
输出结果:
1 2 3
应用场景:
当遇到一个比较耗时的计算量较大的任务时,我们则可以考虑使用多线程来操作,将一个大任务拆分成多个小任务(一个任务相当于一个线程),当每个小任务执行完毕返回结果后,再由某一主线程对结果进行统计。
参考:https://blog.csdn.net/qq_27828675/article/details/114068266
作者:Work Hard Work Smart
出处:http://www.cnblogs.com/linlf03/
欢迎任何形式的转载,未经作者同意,请保留此段声明!