大家好,我是小黑,一个在互联网苟且偷生的农民工。
在上一期我们讲了Thread.join()方法和CountDownLatch,这两者都可以做到等待一个线程执行完毕之后当前线程继续执行,并且CountDownLatch要更优秀,能满足同时等待多个线程执行,我们通过查看源码知道CountDownLatch是通过AQS实现的。
那么在java.util.concurrent包中除了像CountDownLatch
这样的并发控制工具外,还有哪些呢?今天带大家一起来看一看。
CountDownLatch
CountDownLatch从字面理解为“计数器“,回顾昨天的内容,CountDownLatch可以实现等待其他线程执行,并且可以指定等待时间。
举个例子,比如有一个考试,在开考之前老师要等学生到考场,如果所有学生都提前到达,老师可以提前发试卷,但是如果到考试时间有学生还没有到,老师则可以不等,直接开始,我们通过CountDownLatch来模拟一下。
public class CountDownLatchDemo { public static void main(String[] args) throws InterruptedException { CountDownLatch count = new CountDownLatch(5); for (int i = 1; i <= 5; i++) { new Student("学生" + i, count).start(); } // 只等待5秒,5秒之后开始发试卷 count.await(5, TimeUnit.SECONDS); System.out.println("所有学生已到达,老师开始发卷子~"); } } class Student extends Thread { private final CountDownLatch count; public Student(String name, CountDownLatch count) { super(name); this.count = count; } @Override public void run() { try { TimeUnit.SECONDS.sleep(2); System.out.println(Thread.currentThread().getName() + "到达考场~"); count.countDown(); } catch (InterruptedException e) { e.printStackTrace(); } } }