我正在创建一个ExecutorService来执行一些任务,这些任务在正常情况下预计需要一分钟才能完成,但在任何情况下都不允许从任务开始后运行超过两分钟.
我的代码如下:
ExecutorService executorService = Executors.newFixedThreadPool(10);
ArrayList<Future<?>> futuresList = new ArrayList<Future<?>>();
for (String singleTask: taskList) {
futuresList.add(executorService.submit( new Runnable(){
@Override
public void run(){
try {
performTask(p1, singleTask, p3);
} catch (IOException | InterruptedException | ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}));
}
for(Future<?> future : futures) {
future.get(120, TimeUnit.SECONDS);
}
这将阻止直到指定的超时,然后继续.我的问题如下:
1)如果task1阻塞了两分钟而task2也阻塞了两分钟 – 那么task2将被“阻塞”总共4分钟(因为future.get(120,TimeUnit.SECONDS);在task1完成之前不会在task2上调用阻止) – 即使两个任务都已提交并同时开始执行
2)如果我提交了10个以上的任务,那么任务11可能永远不会阻塞所需的时间,如果以前的任务还没有完成,那么future.get(120,TimeUnit.SECONDS);被称为第11任务
我的目标是让每个单独的任务执行最多两分钟,无论列表中的任务数量多少,无论在它之前或之后有多少任务.
谢谢
解决方法:
你可以花时间使用System.currentTimeMillis();然后添加最长时间,例如120_000毫秒.
等你的时候减去当前时间.即你只等到达到最长时间.