java dag_如何在Java中实现类似DAG的调度程序?

我想在

Java中实现一个简单的类似DAG的调度程序(不需要结果),如下图所示:

我可以简单地使用手动代码来实现这个目的:

ExecutorService executor = Executors.newCachedThreadPool();

Future> futureA = executor.submit(new Task("A"));

Future> futureC = executor.submit(new Task("C"));

futureA.get();

Future> futureB = executor.submit(new Task("B"));

futureB.get();

futureC.get();

Future> futureD = executor.submit(new Task("D"));

futureD.get();

但我正在寻找一种更通用的方法,所以我可以像这样使用调度程序:

Container container = new Container();

container.addTask("A", new Task("A"));

container.addTask("B", new Task("B"), "A");

container.addTask("C", new Task("C"));

container.addTask("D", new Task("D"), "B", "C");

container.waitForCompletion();

实际上我已经实现了一个简单的:

但我需要每隔100毫秒迭代一次所有任务,看看哪一个已准备好提交.同样在这个实现中,没有异常检查.

我也检查了Guava lib的ListenableFuture,但我不知道如何正确使用它.

任何关于如何实现DAG或推荐现有开源调度程序的建议都将受到赞赏.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值