Java ExecutorService를 처리할 때 중요한 측면은 모든 작업이 올바르게 종료되도록 종료 프로세스를 처리하는 것입니다. 작업 실행 중에 시간 초과 또는 기타 중단이 발생하면 이는 어려워집니다.
사용자 지정 접근 방식
제공된 코드는 CallableTask 개체를 실행하는 ExecutorService가 어려움에 직면하는 시나리오를 보여줍니다. 모든 작업이 완료된 후 종료됩니다. 이 문제는 제한 시간 임계값을 초과하는 작업 스레드가 활성 상태로 유지되어 실행이 종료되지 않을 가능성이 있기 때문에 발생합니다.
권장 솔루션
이 문제를 해결하려면 Oracle API ExecutorService 문서에서는 다음 접근 방식을 권장합니다.
<code class="java">void shutdownAndAwaitTermination(ExecutorService pool) { pool.shutdown(); try { if (!pool.awaitTermination(60, TimeUnit.SECONDS)) { pool.shutdownNow(); if (!pool.awaitTermination(60, TimeUnit.SECONDS)) System.err.println("Pool did not terminate"); } } catch (InterruptedException ie) { pool.shutdownNow(); Thread.currentThread().interrupt(); } }</code>
이 방법은 순차적인 종료 프로세스를 보장합니다.
종료 관련 메서드 간략 요약
추가 팁
완고한 작업에 대한 종료 시간 초과를 연장하려면 waitTermination():
<code class="java">if (!pool.awaitTermination(60, TimeUnit.SECONDS)) </code>
을 다음과 같이 수정하세요.
<code class="java">while (!pool.awaitTermination(60, TimeUnit.SECONDS)) </code>
이러한 기술을 구현하면 ExecutorService 종료 프로세스의 안정성을 향상시켜 적절한 작업 종료 및 시스템 정리를 보장할 수 있습니다.
위 내용은 Java ExecutorService 종료 중 작업 종료를 확인하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!