Java ExecutorService タスクの例外処理
ExecutorService を利用して重量のあるタスクを実行する場合、発生する可能性のある潜在的な例外を処理することが重要です。 ThreadPoolExecutor の afterExecute メソッドをオーバーライドすると、実行後の例外処理が可能になります。ただし、特定のシナリオでは、afterExecute メソッドが期待どおりに動作しない可能性があります。
次のコード例を考えてみましょう:
public class ThreadPoolErrors extends ThreadPoolExecutor { public ThreadPoolErrors() { super(1, 1, 1, TimeUnit.MINUTES, new LinkedBlockingQueue<Runnable>()); } protected void afterExecute(Runnable r, Throwable t) { super.afterExecute(r, t); if (t != null) { System.out.println("Got an error: " + t); } else { System.out.println("Everything's fine--situation normal!"); } } public static void main(String[] args) { ThreadPoolErrors threadPool = new ThreadPoolErrors(); threadPool.submit( new Runnable() { public void run() { throw new RuntimeException("Ouch! Got an error."); } } ); threadPool.shutdown(); } }
驚くべきことに、このプログラムの出力は「すべて順調です -- 状況」です。正常です!」と表示されますが、送信されたタスクが意図的に例外をスローしたにもかかわらずです。この不一致は、submit メソッドが Runnable の run メソッドを使用しており、署名の一部として例外を宣言していないために発生します。その結果、run メソッド内でスローされた例外はすべて暗黙的に抑制され、afterExecute メソッドに伝播されません。
この問題を解決するには、Runnable の代わりに Callable を使用することを検討してください。 Callable は、実装クラスがその call メソッドによってスローされる可能性のある例外のタイプを宣言することを必要とするインターフェイスです。これにより、ThreadPoolExecutor の afterExecute メソッドは、タスクの実行中に発生する例外を適切に処理および処理できるようになります。
Callable を利用して例外を適切に処理することで、ExecutorService タスクを確実に実行し、エラーを適切に処理できます。
以上がJava `ExecutorService` の実行可能なタスクからの例外を`afterExecute`がキャッチしないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。