ExecutorService로 스레드 완료 대기
ExecutorService를 사용하여 여러 작업을 동시에 실행할 때는 완료 알림을 효과적으로 처리하는 것이 중요합니다. 이 기사에서는 무한 루프에 의존하지 않고 모든 스레드가 완료될 때까지 기다리는 최선의 접근 방식을 탐구합니다.
문제에서 설명했듯이 무한 루프는 최적의 솔루션으로 간주되지 않습니다. 대신 ExecutorService는 작업 완료를 관리하는 내장 메커니즘인 shutdown() 및 waitTermination() 메서드를 제공합니다.
shutdown() 및 waitTermination() 사용
ExecutorService 인터페이스는 ExecutorService에 더 이상 새 작업을 수락하지 않도록 신호를 보내는 shutdown() 메서드를 제공합니다. 현재 제출된 모든 작업이 완료되면 ExecutorService가 종료됩니다.
작업 완료를 기다리기 위해 waitTermination() 메서드가 사용됩니다. 이 메소드는 두 가지 매개변수를 사용합니다.
질문에 제공된 예에서 코드는 다음과 같이 수정될 수 있습니다.
ExecutorService taskExecutor = Executors.newFixedThreadPool(4); while(...) { taskExecutor.execute(new MyTask()); } taskExecutor.shutdown(); try { taskExecutor.awaitTermination(Long.MAX_VALUE, TimeUnit.NANOSECONDS); } catch (InterruptedException e) { ... }
Long.MAX_VALUE 시간 제한은 모든 작업이 완료될 때까지 waitTermination() 메서드가 차단되도록 합니다. 작업 완료가 시간에 민감한 경우 유한한 시간 초과를 지정할 수 있습니다.
결론
shutdown() 및 waitTermination() 메서드를 활용하면 안정적이고 효율적인 방법을 제공합니다. 무한 루프에 의존하지 않고 모든 스레드가 완료될 때까지 기다립니다. 이 접근 방식은 작업 관리를 단순화하고 제어된 방식으로 스레드 완료를 보장합니다.
위 내용은 무한 루프 없이 ExecutorService 스레드 완료를 효율적으로 기다리는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!