찾다
Javajava지도 시간ExecutorService 종료 마스터링: ThreadPool 종료 추적

Mastering ExecutorService Shutdown: Tracking ThreadPool Termination

어떤 작업을 실행하고 싶다고 가정해 보겠습니다. 단일 스레드를 통해 실행하면 결과를 얻는 데 상당한 시간이 걸릴 수 있으므로 신뢰할 수 있는 ExecutorService를 사용하여 여러 스레드를 통해 이를 처리하기로 결정합니다.

샘플은 다음과 같습니다.

public static void main(String[] args) {
    ExecutorService executorService = Executors.newFixedThreadPool(5);
    for (int i = 0; i  {
            task(temp);
        });
    }
    executorService.shutdown();
    System.out.println("ExecutorService is shutdown");
}

private static void task(int temp) {
    try {
        TimeUnit.SECONDS.sleep(1L);
        System.out.println("Task " + temp + " completed");
    } catch (InterruptedException e) {
        throw new RuntimeException(e);
    }
}

물론 평소와 같이 "sleep"을 작업 실행의 원형으로 사용하지 않고는 스레드의 어떤 예도 완성되지 않습니다.

출력됩니다.

ExecutorService is shutdown
Task 1 completed
Task 2 completed
Task 0 completed
Task 4 completed
Task 3 completed

이제 자신도 모르는 작업의 끝없는 대기열이 있다고 상상해 보세요. 아마도 동적으로 추가되는 데이터베이스의 항목 수에 따라 결정될 수도 있습니다.

예를 들어 하루 종일 수많은 거래를 처리해야 하는 은행이 있습니다. 거래 종료 시간은 오후 5시이며, 그 이후에는 추가 작업을 받지 않습니다.

그러나 작업 수는 한정되어 있으며 특정 시점에 종료됩니다.

모든 작업이 완료되는 시점을 어떻게 알 수 있나요?

위의 코드 조각을 보면 ExecutorService.shutdown()을 사용하여 기본 스레드를 즉시 종료할 수 있지만 백그라운드 스레드는 여전히 허용된 작업을 완료까지 처리합니다. 완료 알림을 받을 수 있는 방법이 있나요?

두 가지 솔루션이 떠오릅니다.

  1. CountDownLatch를 사용하여 작업 수를 계산하지만 작업 수를 모르기 때문에 사용하는 것이 비현실적입니다.
  2. ExecutorService.awaitTermination()을 사용하세요. 그러나 여기의 시간은 아직 결정적이지 않습니다. 매우 자유로운 ExecutorService.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS) 또는 이와 유사한 것을 사용할 수 있습니다. 그런데 그게 또 차단전화네요.

이 문제를 해결할 수 있는 더 좋은 방법이 있나요?

Java는 이 문제를 해결할 수 있는 더 좋고 상대적으로 알려지지 않은 방법을 제공합니다. 여기서 "비결"은 Executors.newFixedThreadPool이 본질적으로 사전 정의된 값을 가진 ThreadPoolExecutor라는 것을 아는 것입니다. Executors.newFixedThreadPool의 구현을 확인해 보겠습니다.

public static ExecutorService newFixedThreadPool(int nThreads) {
    return new ThreadPoolExecutor(nThreads, nThreads,
                                  0L, TimeUnit.MILLISECONDS,
                                  new LinkedBlockingQueue<runnable>());
}
</runnable>

여기에서 ThreadPoolExecutor에 대한 문서를 읽어 보시기 바랍니다. ExecutorService는 ThreadPoolExecutor에 대한 편리한 래퍼입니다.

... 프로그래머는 보다 편리한 Executors 팩토리 메소드 Executors.newCachedThreadPool()(자동 스레드 회수 기능이 있는 무제한 스레드 풀), Executors.newFixedThreadPool(int)(고정 크기 스레드 풀) 및 Executors.newSingleThreadExecutor( )(단일 백그라운드 스레드), 가장 일반적인 사용 시나리오에 대한 설정을 사전 구성합니다.

문제 해결에 도움이 되는 섹션은 다음과 같습니다.

후크 방식

이 클래스는 각 작업 실행 전후에 호출되는 재정의 가능한 beforeExecute(Thread, Runnable) 및 afterExecute(Runnable, Throwable) 메서드를 제공합니다. 이는 실행 환경을 조작하는 데 사용될 수 있습니다. 예를 들어 ThreadLocals 다시 초기화, 통계 수집 또는 로그 항목 추가 등이 있습니다. 또한, Executor가 완전히 종료된 후 수행되어야 하는 특수 처리를 수행하기 위해 종료() 메소드를 재정의할 수 있습니다.

해지 방법을 사용하여 동일한 내용을 통보할 수 있습니다! 그런데 어떻게 사용하나요?

public static void main(String[] args) {
    ExecutorService executorService = Executors.newFixedThreadPool(5);
    for (int i = 0; i  {
            task(temp);
        });
    }
    executorService.shutdown();
    System.out.println("ExecutorService is shutdown");
}

private static void task(int temp) {
    try {
        TimeUnit.SECONDS.sleep(1L);
        System.out.println("Task " + temp + " completed");
    } catch (InterruptedException e) {
        throw new RuntimeException(e);
    }
}

나처럼 익명 클래스를 선호하지 않는 경우 언제든지 ThreadPoolExecutor를 직접 확장하여 사용자 정의 클래스를 만들 수 있습니다.

ExecutorService is shutdown
Task 1 completed
Task 2 completed
Task 0 completed
Task 4 completed
Task 3 completed

예상대로 작동하는지 확인하기 위한 출력은 다음과 같습니다.

public static ExecutorService newFixedThreadPool(int nThreads) {
    return new ThreadPoolExecutor(nThreads, nThreads,
                                  0L, TimeUnit.MILLISECONDS,
                                  new LinkedBlockingQueue<runnable>());
}
</runnable>

당신이 사용하는 상대적으로 알려지지 않은 다른 스니펫은 무엇입니까? 댓글로 알려주세요!

위 내용은 ExecutorService 종료 마스터링: ThreadPool 종료 추적의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
JVM의 클래스 로더 서브 시스템은 플랫폼 독립성에 어떻게 기여합니까?JVM의 클래스 로더 서브 시스템은 플랫폼 독립성에 어떻게 기여합니까?Apr 23, 2025 am 12:14 AM

클래스 로더는 통합 클래스 파일 형식, 동적로드, 부모 위임 모델 및 플랫폼 독립적 인 바이트 코드를 통해 다른 플랫폼에서 Java 프로그램의 일관성과 호환성을 보장하고 플랫폼 독립성을 달성합니다.

Java 컴파일러는 플랫폼 별 코드를 생성합니까? 설명하다.Java 컴파일러는 플랫폼 별 코드를 생성합니까? 설명하다.Apr 23, 2025 am 12:09 AM

Java 컴파일러가 생성 한 코드는 플랫폼 독립적이지만 궁극적으로 실행되는 코드는 플랫폼 별입니다. 1. Java 소스 코드는 플랫폼 독립적 인 바이트 코드로 컴파일됩니다. 2. JVM은 바이트 코드를 특정 플랫폼의 기계 코드로 변환하여 크로스 플랫폼 작동을 보장하지만 성능이 다를 수 있습니다.

JVM은 다른 운영 체제에서 멀티 스레딩을 어떻게 처리합니까?JVM은 다른 운영 체제에서 멀티 스레딩을 어떻게 처리합니까?Apr 23, 2025 am 12:07 AM

멀티 스레딩은 프로그램 대응 성과 리소스 활용을 향상시키고 복잡한 동시 작업을 처리 할 수 ​​있기 때문에 현대 프로그래밍에서 중요합니다. JVM은 스레드 매핑, 스케줄링 메커니즘 및 동기화 잠금 메커니즘을 통해 다양한 운영 체제에서 멀티 스레드의 일관성과 효율성을 보장합니다.

'플랫폼 독립성'은 Java의 맥락에서 무엇을 의미합니까?'플랫폼 독립성'은 Java의 맥락에서 무엇을 의미합니까?Apr 23, 2025 am 12:05 AM

Java의 플랫폼 독립성은 작성된 코드가 수정없이 JVM이 설치된 모든 플랫폼에서 실행될 수 있음을 의미합니다. 1) Java 소스 코드는 바이트 코드로 컴파일됩니다. 2) 바이트 코드는 JVM에 의해 해석되고 실행됩니다.

Java 응용 프로그램이 여전히 플랫폼 별 버그 또는 문제를 만날 수 있습니까?Java 응용 프로그램이 여전히 플랫폼 별 버그 또는 문제를 만날 수 있습니까?Apr 23, 2025 am 12:03 AM

javaapplicationscanindeedencounterplatform-specificissuesdespitetejvm'sabstraction.ressistinclude : 1) nativecodeandlibraries, 2) OperatingSystemDifferences, 3) jvmimplementationvariations, 및 4) 어려운 의존성, 개발자, 1)

클라우드 컴퓨팅은 Java의 플랫폼 독립성의 중요성에 어떤 영향을 미칩니 까?클라우드 컴퓨팅은 Java의 플랫폼 독립성의 중요성에 어떤 영향을 미칩니 까?Apr 22, 2025 pm 07:05 PM

클라우드 컴퓨팅은 Java의 플랫폼 독립성을 크게 향상시킵니다. 1) Java Code는 바이트 코드로 컴파일되어 다른 운영 체제에서 JVM에 의해 실행되어 크로스 플랫폼 작동을 보장합니다. 2) Docker 및 Kubernetes를 사용하여 Java 응용 프로그램을 배포하여 휴대 성 및 확장 성을 향상시킵니다.

Java의 플랫폼 Independence는 광범위한 채택에서 어떤 역할을 했습니까?Java의 플랫폼 Independence는 광범위한 채택에서 어떤 역할을 했습니까?Apr 22, 2025 pm 06:53 PM

Java'SplatformIndencealLowsDeveloperstowStowRiteCodeOntOnitOniNanyDeviceOroswithajvm. ThisIsachieAdthroughCompilingTobyTecode, thejvMIngretSorcompileStruntime.thistureatureDificallyNatlyBoostedjava'SADOPTIONDUOCROSS-PLAT-PLAT-PLAT-PLAT-PLAT-PLAT-PLAT-PLAT-PPLATION

Docker와 같은 컨테이너화 기술 (Docker)은 Java의 플랫폼 독립성의 중요성에 어떤 영향을 미칩니 까?Docker와 같은 컨테이너화 기술 (Docker)은 Java의 플랫폼 독립성의 중요성에 어떤 영향을 미칩니 까?Apr 22, 2025 pm 06:49 PM

Docker와 같은 컨테이너화 기술은 Java의 플랫폼 독립성을 대체하기보다는 향상됩니다. 1) 환경 간 일관성을 보장, 2) 특정 JVM 버전을 포함한 종속성 관리, 3) 배포 프로세스를 단순화하여 Java 응용 프로그램을보다 적응 가능하고 관리 할 수 ​​있도록합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.