天天看点

多线程:CountDownLatch Demo

示例: 多线程等待前置任务完成

package com.yqzl.mybatis.test.thread.demo01;

import java.util.Random;
import java.util.concurrent.CountDownLatch;

/**
* @description:
* @author: YqZhilan
* @date: 2020-07-16
*/
public class CountDownLatchDemo {

    static class PreTaskThread implements Runnable {

        private String task;
        private CountDownLatch countDownLatch;

        public PreTaskThread (String task, CountDownLatch countDownLatch) {
            this.task = task;
            this.countDownLatch = countDownLatch;
        }

        @Override
        public void run() {

            Random random = new Random();
            try {
                Thread.sleep(random.nextInt(1000));
                System.out.println(task + " - 任务完成");
                countDownLatch.countDown();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }

        public static void main(String[] args) {
            CountDownLatch countDownLatch = new CountDownLatch(3);

            new Thread(()->{
                try {
                    System.out.println("等待加载数据 ... ...");
                    System.out.println(String.format("前面还有%d个前置任务", countDownLatch.getCount()));
                    countDownLatch.await();
                    System.out.println("加载数据完成,现在开始!");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }).start();

            new Thread(new PreTaskThread("加载地图数据", countDownLatch)).start();
            new Thread(new PreTaskThread("加载人物模型", countDownLatch)).start();
            new Thread(new PreTaskThread("加载背景音乐", countDownLatch)).start();
        }
    }
}
           

返回结果:

等待加载数据 ... ...
加载背景音乐 - 任务完成
前面还有3个前置任务
加载地图数据 - 任务完成
加载人物模型 - 任务完成
加载数据完成,现在开始!
           

继续阅读