CountDownLatch
CountDownLatch 计数器,初始化是指定count初始值,await()方法将造成阻塞,直到调用 countDown()方法将count值减为零,这是将释放所有阻塞在await()处的线程。CountDownLatch 是一次性的不能重置count值。
// 倒计数10
CountDownLatch countDownLatch = new CountDownLatch(10);
for (int i = 0; i < 10; i++) {
final int tempInt = i;
new Thread(()->{
try {
System.out.println(tempInt + "do something");
Thread.sleep(200);
} catch (InterruptedException e) {
e.printStackTrace();
}finally {
countDownLatch.countDown();
}
// 完成减 1
},"thread"+i).start();
}
// 在此处阻塞直到 countDownLatch 的count为零
countDownLatch.await();
System.out.println("其他任务已经完成");
执行结果
0do something
2do something
1do something
3do something
4do something
5do something
6do something
7do something
8do something
9do something
其他任务已经完成
CyclicBarrier
循环屏障,与CountDownLatch 很类似,CyclicBarrier的 await()方法阻塞线程,直到阻塞线程数达到指定的初始值,执行完成指定任务后(也可不指定),唤醒所有等待线程。CyclicBarrier使用reset()重置。
CyclicBarrier cyclicBarrier = new CyclicBarrier(10,()->{
System.out.println("-----> 十个线程都在等我");
});
for (int i = 0; i < 10; i++) {
new Thread(()->{
try {
System.out.println(Thread.currentThread().getName()+"开始等待");
cyclicBarrier.await();
System.out.println(Thread.currentThread().getName()+"等待结束");
}catch (Exception e) {
e.printStackTrace();
}
},"thread "+i).start();
}
thread 1开始等待
thread 0开始等待
thread 2开始等待
thread 3开始等待
thread 4开始等待
thread 5开始等待
thread 6开始等待
thread 8开始等待
thread 9开始等待
thread 7开始等待
-----> 十个线程都在等我
thread 7等待结束
thread 1等待结束
thread 0等待结束
thread 2等待结束
thread 5等待结束
thread 8等待结束
thread 6等待结束
thread 3等待结束
thread 4等待结束
thread 9等待结束
总结
CountDownLatch倒计时,阻塞在 await处; CyclicBarrier的 await阻塞,直到阻塞数量到达指定值;