【问题标题】:traversing a List<Future> object throws IndexOutOfBounds exception遍历 List<Future> 对象会引发 IndexOutOfBounds 异常
【发布时间】:2015-07-23 18:50:07
【问题描述】:

我有一个 ExecutorService,它用于调用 Callable 对象集合并返回与集合中的 Callable 元素对应的 Future 对象列表。

但是,在遍历列表的某个地方,它会抛出以下异常:

java.util.concurrent.ExecutionException: java.lang.IndexOutOfBoundsException: Index: 7, Size: 1
at java.util.concurrent.FutureTask.report(Unknown Source)
at java.util.concurrent.FutureTask.get(Unknown Source)
at com.soc.transformcsv.ParallelTransformationPool.doExecute(ParallelTransformationPool.java:91)

我一直在执行的代码是

List<Future<StringBuilder>> futures = executor.invokeAll(builders);
executor.shutdown();
HashMap<String, List<StringBuilder>> allServiceTypeRows = new LinkedHashMap<>();

for (Future<StringBuilder> future : futures) {
    // I have tried putting future.isDone() which always prints true before the exception
    StringBuilder recordBuilder = future.get();
    // do more
}

它在future.get() 行给了我错误。

请帮助解决障碍或让我知道我还能提供什么。

【问题讨论】:

    标签: java future executorservice futuretask


    【解决方案1】:

    isDone() 的结果可能为真即使 Callable 中有异常。来自isDone documentation

    如果此任务完成,则返回 true。完成可能是由于正常终止、异常或取消 - 在所有这些情况下,此方法都将返回 true。

    因此,有问题的 Future 已完成,但在计算时遇到错误。在您发布的堆栈跟踪下,应该有另一个,列出“Caused by:”——这将在您的 Callable 中出现根故障。

    例如,查看this ideone link 的输出。在成功检查isDone 为真之后 出现此异常:

    Exception in thread "main" java.util.concurrent.ExecutionException: java.lang.RuntimeException: This is a failure!
        at java.util.concurrent.FutureTask.report(FutureTask.java:122)
        at java.util.concurrent.FutureTask.get(FutureTask.java:192)
        at Ideone.main(Main.java:16)
    Caused by: java.lang.RuntimeException: This is a failure!
        at Ideone$SampleCallable.call(Main.java:21)
        at Ideone$SampleCallable.call(Main.java:19)
        at java.util.concurrent.FutureTask.run(FutureTask.java:266)
        at Ideone.main(Main.java:14)
    

    【讨论】:

    • 是的,根故障为我提供了OutOfMemoryError,我知道它发生在执行特定任务时。我在上面。
    【解决方案2】:

    遍历List&lt;Future&gt; 不会发生异常。实际上IndexOutOfBoundsException 发生在ExecutorService 执行call()Callable 方法时@(builders 之一)。

    但仅当您尝试使用future.get() 获取Future 的结果时,才会引发此异常(包装在ExecutionException 中)。

    【讨论】:

      猜你喜欢
      • 2012-11-08
      • 2022-06-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-02-07
      • 1970-01-01
      • 2016-03-19
      相关资源
      最近更新 更多