大家好,我是小黑,一个在互联网苟且偷生的农民工。

在上一期我们讲了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();
        }
    }
}

 

故乡明