当前位置:首页 > 科技  > 软件

面试官:一个子任务要依赖两个父任务完成才能执行,该怎么设计?

来源: 责编: 时间:2024-09-10 09:44:01 40观看
导读大家好,我是君哥。今天分享一道面试题。面试官:有一个场景,如果一个子任务的执行,要依赖两个父任务执行完成后才能执行,该怎么设计? 我:可以设置两个父任务的信号,父任务执行完成后更新信号已完成。子任务被触发时判断两个父

大家好,我是君哥。今天分享一道面试题。I6X28资讯网——每日最新资讯28at.com

面试官:有一个场景,如果一个子任务的执行,要依赖两个父任务执行完成后才能执行,该怎么设计? I6X28资讯网——每日最新资讯28at.com

:可以设置两个父任务的信号,父任务执行完成后更新信号已完成。子任务被触发时判断两个父任务是否执行完成,只有两个父任务都执行完成,子任务才会执行。如果条件不满足,就先挂起。下面是一段示例代码:I6X28资讯网——每日最新资讯28at.com

private static AtomicInteger parentTask1 = new AtomicInteger(0);private static AtomicInteger parentTask2 = new AtomicInteger(0);private static Object locker = new Object();public static void main(String[] args) throws InterruptedException { Thread childThread = new Thread(() -> {  while (true) {   try {    synchronized (locker) {     if (parentTask1.get() == 1 && parentTask2.get() == 1) {      //doSomething      break;     }     locker.wait();    }   } catch (InterruptedException e) {    e.printStackTrace();   }  } }); childThread.start(); Thread parentThread1 = new Thread(() -> {  parentTask1.incrementAndGet();  synchronized (locker){   locker.notifyAll();  } }); parentThread1.start();}

父任务执行完成后唤醒子任务。I6X28资讯网——每日最新资讯28at.com

面试官:有其他方法吗? I6X28资讯网——每日最新资讯28at.com

:也可以使用 CompletableFuture,使用任务依赖来控制任务执行,下面是一个示例代码:I6X28资讯网——每日最新资讯28at.com

CompletableFuture<Boolean> parentTask1 = CompletableFuture.supplyAsync(() -> { System.out.println("doParentTask1"); return true;});CompletableFuture<Boolean> parentTask2 = CompletableFuture.supplyAsync(() -> { System.out.println("doParentTask2"); return true;});CompletableFuture childTask = CompletableFuture.allOf(parentTask1, parentTask2);childTask.thenApply(c -> { try {  if (parentTask1.get() && parentTask2.get()){   System.out.println("doChildTask");  } } catch(Exception e) {  e.printStackTrace(); } finally {  System.out.println("child task do error"); } return c;});childTask.join();

面试官:那在分布式场景或集群环境下,前面说的方案可以解决问题吗? I6X28资讯网——每日最新资讯28at.com

:分布式场景或者集群环境下,肯定是不能使用上面的线程调度方案的,因为多个任务可能跑在不同进程里。I6X28资讯网——每日最新资讯28at.com

面试官:现在开源的分布式任务调度框架有很多,比如 xxl-job、PowerJob,有这个场景相关的调度方案吗? I6X28资讯网——每日最新资讯28at.com

:目前的任务调度框架支持子任务配置,但是还没有子任务依赖两个父任务执行结果这个场景的配置。I6X28资讯网——每日最新资讯28at.com

面试官:那有什么方案可以解决分布式场景下的问题吗? I6X28资讯网——每日最新资讯28at.com

:我想到一个简单的方案,可以在数据库或缓存中维护一个父任务的状态标志,比如一张状态表保存 parentTask1、parentTask2 这两个任务状态,每当子任务被触发时先查一下这两个状态是否都被更新成 1,如果是再执行业务逻辑,否则直接退出任务。I6X28资讯网——每日最新资讯28at.com

面试官:你说的这个方案,如果只跑一次,还可以,如果任务执行比较频繁,比如两个父任务每分钟跑一次,子任务也会每分钟都会被触发。你这个方案能满足要求吗? I6X28资讯网——每日最新资讯28at.com

:一分钟频率太高了,需要记录每次父任务的状态,而且同一个父任务每分钟执行的状态要能区分开。因为可能有极端的情况,parentTask1 上一分钟的还没有跑完,但 parentTask2 下一分钟的已经跑完了,父子任务关联会出现混乱,如果子任务依赖父任务跑批产生的数据,就会出问题。I6X28资讯网——每日最新资讯28at.com

面试官:嗯,你说的这个情况是存在的,如果让你设计,你会怎么解决呢I6X28资讯网——每日最新资讯28at.com

:可以给父子任务赋值一个 taskId,根据这个 taskId 来做关联。比如 parentTask1 的 taskId 是 P202409100000011,parentTask2 配套的 taskId 是 P202409100000012,子任务配套的 taskId 是 P202409100000013。子任务被触发时,根据 P202409100000013 来判断  P202409100000011 和 P202409100000012 是否执行完成。子任务下一次触发时,taskId 就是 P202409100000023,下下次就是 P202409100000033,每次子任务 Id 都是根据父任务 taskId 计算出来。I6X28资讯网——每日最新资讯28at.com

面试官:这个 taskId 怎么生成和关联,有思路吗? I6X28资讯网——每日最新资讯28at.com

:这个还是有点难度的。我说一个思路,不一定好。我们定义一张表,如下图:I6X28资讯网——每日最新资讯28at.com

图片图片I6X28资讯网——每日最新资讯28at.com

给这个场景定义一个自增 id,这个 id 由 parentTask1 来获取,获取后先进行记录再执行任务。parentTask2 启动时,找到 parentTask1 有值但是 parentTask2 为空的记录。先根据 parentTask1 的记录taskId 计算出自己的 taskId,然后保存数据库。而子任务被触发时,从表里查询已经有 parent_task1_id 和 parent_task2_id 并且两个状态都为 1,但是没有 child_task_id 的记录,更新 child_task_id 字段,然后执行任务逻辑。I6X28资讯网——每日最新资讯28at.com

面试官:恭喜你进入下一轮。I6X28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-112704-0.html面试官:一个子任务要依赖两个父任务完成才能执行,该怎么设计?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Asp.Net Core实战-MiniProfiler性能分析

下一篇: 在PHP编程中,将数据快速转换为JSON格式

标签:
  • 热门焦点
  • 线程通讯的三种方法!通俗易懂

    线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • 2023 年的 Node.js 生态系统

    2023 年的 Node.js 生态系统

    随着技术的不断演进和创新,Node.js 在 2023 年达到了一个新的高度。Node.js 拥有一个庞大的生态系统,可以帮助开发人员更快地实现复杂的应用。本文就来看看 Node.js 最新的生
  • 一文看懂为苹果Vision Pro开发应用程序

    一文看懂为苹果Vision Pro开发应用程序

    译者 | 布加迪审校 | 重楼苹果的Vision Pro是一款混合现实(MR)头戴设备。Vision Pro结合了虚拟现实(VR)和增强现实(AR)的沉浸感。其高分辨率显示屏、先进的传感器和强大的处理能力
  • 如何通过Python线程池实现异步编程?

    如何通过Python线程池实现异步编程?

    线程池的概念和基本原理线程池是一种并发处理机制,它可以在程序启动时创建一组线程,并将它们置于等待任务的状态。当任务到达时,线程池中的某个线程会被唤醒并执行任务,执行完任
  • 小红书1周涨粉49W+,我总结了小白可以用的N条涨粉笔记

    小红书1周涨粉49W+,我总结了小白可以用的N条涨粉笔记

    作者:黄河懂运营一条性教育视频,被54万人&ldquo;珍藏&rdquo;是什么体验?最近,情感博主@公主是用鲜花做的,火了!仅仅凭借一条视频,光小红书就有超过128万人,为她疯狂点赞!更疯狂的是,这
  • 雅柏威士忌多款单品价格大跌,泥煤顶流也不香了?

    雅柏威士忌多款单品价格大跌,泥煤顶流也不香了?

    来源 | 烈酒商业观察编 | 肖海林今年以来,威士忌市场开始出现了降温迹象,越来越多不断暴涨的网红威士忌也开始悄然回归市场理性。近日,LVMH集团旗下苏格兰威士忌品牌雅柏(Ardbeg
  • 华为和江淮汽车合作开发百万元问界MPV?双方回应来了

    华为和江淮汽车合作开发百万元问界MPV?双方回应来了

    8月1日消息,郭明錤今天在社交平台发文称,华为正在和江淮汽车合作,开发售价在100万元的问界MPV,预计在2024年第2季度量产,销量目标为上市首年交付5万辆。
  • onebot M24巧系列一体机采用轻薄机身设计,现已在各平台开售

    onebot M24巧系列一体机采用轻薄机身设计,现已在各平台开售

    onebot M24 巧系列一体机目前已在线上线下各平台同步开售。onebot M24 巧系列采用一体化轻薄机身设计,最薄处为 10.15mm,拥有宝石红、午夜蓝、石墨绿、雅致
  • 由于成本持续增加,笔记本产品价格预计将明显上涨

    由于成本持续增加,笔记本产品价格预计将明显上涨

    根据知情人士透露,由于材料、物流等成本持续增加,笔记本产品价格预计将在2021年下半年有明显上涨。进入6月下旬以来,全球半导体芯片缺货情况加剧,显卡、处理器
Top