gpt4 book ai didi

Java ExecutorService - 监控任务完成/状态栏

转载 作者:行者123 更新时间:2023-11-29 18:35:30 28 4
gpt4 key购买 nike

所以我现在有一个 ExecutorService 成功地阻塞并线性运行。我的麻烦是,我正在尝试添加状态更新,但我不知道如何让 Futures 一次结算一个项目。似乎当我的 Future<> 中的第一项准备就绪时,最后一项也准备好了。我希望找到一个可以知道我的 executorService 剩余/总任务数的地方,这样我就可以计算一个简单的百分比指标。请注意,我打算回收我的 Executor 并且不想关闭它。

ExecutorService updateService = Executors.newSingleThreadExecutor();
Callable<String> callHour = () -> {
//doStuff, unaware of total number of hourCalls
return "done";
};
private void startMe(int hours){
List<Future<String>> futureHours;
List<Callable<String>> hourCalls = new ArrayList<>(hours);
for (int hour = 0; hour < hours; ++hour) {
hourCalls.add(callHour); //queue list (not running yet)
}
try {
//executes queue and blocks thread
futureHours = updateService.invokeAll(hourCalls);
futureHours.get(0).get();//performs blocking
} catch (Exception e) {
e.printStackTrace();
}
}
}

最佳答案

这里有两件事在起作用。


首先,如果我们看一下 the documentation of ExecutorService#invokeAll(...) ,我们看到它返回

[...] a list of Futures holding their status and results when all complete. [...]

(重点是我加的)

您很可能想使用 Executor#submit(...)相反。


其次,您无法保证与 futureHours.get(0) 耦合的任务首先执行。我建议使用 Future#isDone()加上一些额外的逻辑:

private void startMe(int hours) {
[...]
try {
[...]
ArrayList<Future<String>> futureHoursDone = new ArrayList<>();
final int numTasks = futureHours.size();
int done = 0;
double percentageDone = 0.0d;
while (futureHours.isEmpty() == false) {
for (int index = 0; index < futureHours.size(); ++index) {
Future<String> futureHour = futureHours.get(index);
if (futureHour.isDone()) {
futureHours.remove(index);
futureHoursDone.add(futureHour);
--index;
++done;
percentageDone = done / (double) numTasks;
}
}
}
} catch (Exception e) {
// TODO: don't forget to HCF (https://en.wikipedia.org/wiki/Halt_and_Catch_Fire) :)
e.printStackTrace();
}
}

(这是一个粗略的草图。要取得进展,即 percentage,对外部可见,您必须使其成为一个属性并通过例如一些 getter 访问)

关于Java ExecutorService - 监控任务完成/状态栏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54544133/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com