0

私のコードの 2 番目のスレッドは 0 による除算の例外をスローしますが、最初のスレッドが終了した後にのみキャッチします。最初のスレッドは数日間実行される可能性があるため、例外が発生してから数日後にのみ例外をキャッチすることになります。ThreadPoolExecutor をサブクラス化し、afterExecute をオーバーライドせずに、どうにかしてこれを解決できますか?

これが私のコードです:

    ExecutorService executor = Executors.newCachedThreadPool();

    Future<Integer> future = executor.submit(new MyTestC(4000));
    Future<Integer> future2 = executor.submit(new MyTestC(0));

    ArrayList<Future<Integer>> futures = new ArrayList<>();
    futures.add(future); futures.add(future2);

    for(Future<Integer> f: futures)
    {
        try {
            int result = f.get();
            System.out.println(result);
        } catch (InterruptedException | ExecutionException e) {
            e.printStackTrace();
        }
    }

class MyTestC implements Callable<Integer> {

int sleep;

public MyTestC(int sleep)
{
    this.sleep = sleep;
}

@Override
public Integer call() throws Exception {
    if(sleep > 0)
        Thread.sleep(sleep);

    //If 0 will throw exception:
    int tmp = 4/sleep;

    return sleep;
}

}

4

1 に答える 1

2

ExecutorCompletionServiceを使用してこの問題を解決できます。完了した順序で先物を返します。

于 2013-04-06T12:57:53.453 に答える