CountDownLatch

打印 上一主题 下一主题

主题 869|帖子 869|积分 2607

想象一下,你正在组织一次家庭聚会。为了确保统统都按计划举行,你需要完成几项准备工作,好比部署餐桌、准备食品和装饰房间。你希望所有的准备工作都完成后,再正式开始聚会。为了协调这些任务,你可以使用类似 CountDownLatch 的机制。
使用 CountDownLatch 协调任务


  • 设置倒计时:首先,你确定了有三项主要的准备工作需要完成(部署餐桌、准备食品、装饰房间),于是你创建了一个 CountDownLatch 并设置它的计数为3。
  • 分配任务:接下来,你把差别的任务分配给家庭成员。每个成员负责一项特定的任务,并且在他们完成自己的任务后,他们会告诉 CountDownLatch 他们的部门已经完成了。
  • 等待所有任务完成:与此同时,你(作为组织者)会等待 CountDownLatch 的计数归零,这意味着所有的准备工作都已经完成了。一旦计数归零,你就知道所有的工作都已经完成,现在可以正式开始聚会了。
  • 启动聚会:当 CountDownLatch 的计数变为0时,它会释放等待中的线程,允许你公布聚会正式开始。
Java 中的 CountDownLatch 示例

下面是一个简化的 Java 示例,展示了如何使用 CountDownLatch 来协调并发任务:
  1. import java.util.concurrent.CountDownLatch;
  2. public class FamilyPartyPreparation {
  3.     public static void main(String[] args) throws InterruptedException {
  4.         // 创建一个 CountDownLatch,初始计数为3,代表三个任务
  5.         CountDownLatch latch = new CountDownLatch(3);
  6.         // 创建并启动三个线程,每个线程负责一项任务
  7.         Thread setupTable = new Thread(() -> {
  8.             System.out.println("布置餐桌...");
  9.             try {
  10.                 Thread.sleep(2000); // 模拟任务耗时
  11.             } catch (InterruptedException e) {
  12.                 e.printStackTrace();
  13.             }
  14.             System.out.println("餐桌布置完毕!");
  15.             latch.countDown(); // 完成任务,计数减1
  16.         });
  17.         Thread prepareFood = new Thread(() -> {
  18.             System.out.println("准备食物...");
  19.             try {
  20.                 Thread.sleep(3000); // 模拟任务耗时
  21.             } catch (InterruptedException e) {
  22.                 e.printStackTrace();
  23.             }
  24.             System.out.println("食物准备完毕!");
  25.             latch.countDown(); // 完成任务,计数减1
  26.         });
  27.         Thread decorateRoom = new Thread(() -> {
  28.             System.out.println("装饰房间...");
  29.             try {
  30.                 Thread.sleep(2500); // 模拟任务耗时
  31.             } catch (InterruptedException e) {
  32.                 e.printStackTrace();
  33.             }
  34.             System.out.println("房间装饰完毕!");
  35.             latch.countDown(); // 完成任务,计数减1
  36.         });
  37.         // 启动所有线程
  38.         setupTable.start();
  39.         prepareFood.start();
  40.         decorateRoom.start();
  41.         // 等待所有任务完成
  42.         System.out.println("等待所有准备工作完成...");
  43.         latch.await(); // 主线程在此处阻塞,直到计数归零
  44.         // 所有任务完成,开始聚会
  45.         System.out.println("所有准备工作已完成,聚会正式开始!");
  46.     }
  47. }
复制代码
在这个例子中:


  • CountDownLatch 的计数被初始化为3,对应三项准备工作。
  • 每个任务由一个独立的线程执行,当任务完成时,该线程调用 latch.countDown() 方法淘汰计数。
  • 主线程调用 latch.await() 方法,这将使主线程暂停执行,直到 CountDownLatch 的计数归零,即所有任务都已完成。
  • 一旦计数归零,主线程继续执行,表现所有准备工作已经完成,聚会可以正式开始了。
  CountDownLatch 是一个非常有用的工具,用于协调多个线程之间的利用,特别是在你需要确保一组任务全部完成后才能继续下一步的环境下。通过设定一个初始计数,并让每个完成任务的线程淘汰这个计数,CountDownLatch 可以有效地管理并发任务的完成环境,并通知等待的线程何时可以继续前进。这种机制非常适适用来同步多个并发任务或阶段性的任务完成检查。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

西河刘卡车医

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表