> Java > java지도 시간 > 무한 루프 없이 ExecutorService 스레드 완료를 효율적으로 기다리는 방법은 무엇입니까?

무한 루프 없이 ExecutorService 스레드 완료를 효율적으로 기다리는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-14 17:41:16
원래의
147명이 탐색했습니다.

How to Efficiently Wait for ExecutorService Thread Completion Without Infinite Loops?

ExecutorService로 스레드 완료 대기

ExecutorService를 사용하여 여러 작업을 동시에 실행할 때는 완료 알림을 효과적으로 처리하는 것이 중요합니다. 이 기사에서는 무한 루프에 의존하지 않고 모든 스레드가 완료될 때까지 기다리는 최선의 접근 방식을 탐구합니다.

문제에서 설명했듯이 무한 루프는 최적의 솔루션으로 간주되지 않습니다. 대신 ExecutorService는 작업 완료를 관리하는 내장 메커니즘인 shutdown() 및 waitTermination() 메서드를 제공합니다.

shutdown() 및 waitTermination() 사용

ExecutorService 인터페이스는 ExecutorService에 더 이상 새 작업을 수락하지 않도록 신호를 보내는 shutdown() 메서드를 제공합니다. 현재 제출된 모든 작업이 완료되면 ExecutorService가 종료됩니다.

작업 완료를 기다리기 위해 waitTermination() 메서드가 사용됩니다. 이 메소드는 두 가지 매개변수를 사용합니다.

  • timeout: 작업 완료를 기다리는 최대 시간을 지정합니다.
  • timeUnit: 시간 초과의 시간 단위.

질문에 제공된 예에서 코드는 다음과 같이 수정될 수 있습니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿