Java スレッド割り込みタイムアウト エラー例外 (ThreadInterruptedTimeoutErrorException) を解決する方法
Java 開発プロセスでは、同時実行のパフォーマンスと効率を向上させるためにマルチスレッドを使用することがよくあります。プログラムの。ただし、スレッドを使用すると、スレッド タイムアウト エラー例外 (ThreadInterruptedTimeoutErrorException) などの問題が発生する可能性があります。この記事では、この問題を解決する方法と、対応するコード例を示します。
2.1 join() メソッドを使用します。
Java では、 Thread を使用できます。 クラスが提供する join() メソッドは、スレッドの終了を待つために使用されます。このメソッドは、join() メソッドが呼び出されたスレッドが終了するかタイムアウトになるまで、現在のスレッドを一時停止します。 join()メソッド呼び出し時にタイムアウトを設定することができ、タイムアウト時間内にスレッドが終了しない場合は、スレッドタイムアウトエラー例外が発生したとみなします。以下に簡単なサンプル コードを示します。
Thread thread = new Thread(() -> { // 执行一些耗时的操作 }); thread.start(); thread.join(1000); // 设置超时时间为1秒 if (thread.isAlive()) { // 线程超时错误处理逻辑 thread.interrupt(); // 中断线程 }
2.2 wait() メソッドと Notify() メソッドの使用
別の解決策は、wait() メソッドと Notify() メソッドを使用して、スレッドの待機とウェイクアップを実装することです。 。待機中のスレッドで wait() メソッドを使用してタイムアウトを設定できます。待機中に別のスレッドでいくつかの操作を実行できます。操作が完了したら、notify() メソッドを使用して待機中のスレッドに通知します。以下はサンプル コードです。
Object lock = new Object(); boolean isOperationComplete = false; Thread waitingThread = new Thread(() -> { synchronized (lock) { try { lock.wait(1000); // 设置超时时间为1秒 } catch (InterruptedException e) { e.printStackTrace(); } if (!isOperationComplete) { // 线程超时错误处理逻辑 } } }); Thread executingThread = new Thread(() -> { // 执行一些操作 synchronized (lock) { isOperationComplete = true; lock.notify(); } }); waitingThread.start(); executingThread.start();
2.3 ExecutorService と Future の使用
Java の ExecutorService と Future は、スレッドの管理と制御に使用されるツール クラスです。 ExecutorService を使用してタイムアウトのあるタスクを送信し、Future の get() メソッドを使用してタスクの結果を取得することができます。タイムアウト期間内にタスクが完了しない場合は、スレッド タイムアウト エラー例外が発生したと考えることができます。 。以下はサンプル コードです。
ExecutorService executorService = Executors.newFixedThreadPool(1); Future<?> future = executorService.submit(() -> { // 执行一些耗时的操作 }); try { future.get(1, TimeUnit.SECONDS); // 设置超时时间为1秒 } catch (InterruptedException | ExecutionException | TimeoutException e) { // 线程超时错误处理逻辑 future.cancel(true); // 取消任务 } executorService.shutdown();
以上がJavaスレッド割り込みタイムアウトエラー例外(ThreadInterruptedTimeoutErrorExceotion)の解決方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。