Java에서 스레드 실행 조정
멀티 스레드 애플리케이션에서는 여러 스레드에 걸쳐 작업 완료를 동기화해야 하는 경우가 많습니다. 이는 한 스레드의 실행 결과가 다른 스레드의 완료에 따라 달라질 때 특히 그렇습니다. 이러한 맥락에서 Java 프로그램의 모든 스레드가 작업을 완료한 시기를 확인하는 방법을 살펴보겠습니다.
문제 설명:
5개의 스레드가 동시에 있는 애플리케이션이 있습니다. 웹에서 데이터를 검색하고 공유 버퍼 클래스에 5개의 개별 필드를 채웁니다. 목표는 모든 스레드가 작업을 완료한 후 버퍼 데이터의 유효성을 검사하고 데이터베이스에 저장하는 것입니다. 핵심 과제는 모든 스레드의 실행이 완료되는 순간을 식별하는 것입니다.
해결책:
스레드 풀을 관리하는 효과적인 접근 방식 중 하나는 ExecutorService를 사용하는 것입니다. 스레드를 생성하고 관리하는 편리한 방법을 제공합니다. 이 솔루션을 구현하는 방법은 다음과 같습니다.
ExecutorService es = Executors.newCachedThreadPool(); for (int i = 0; i < 5; i++) { es.execute(new Runnable() { /* Implement your task */ }); } es.shutdown(); boolean finished = es.awaitTermination(1, TimeUnit.MINUTES); // All tasks have finished or the time has been reached.
이 코드 조각에서는 먼저 Executors.newCachedThreadPool() 메서드를 사용하여 ExecutorService를 생성합니다. 이렇게 하면 제출된 작업 수에 따라 크기를 동적으로 조정하는 스레드 풀이 생성됩니다. 그런 다음 Executor 서비스에 5개의 작업을 제출합니다.
모든 작업이 제출되면 shutdown() 메소드를 호출하여 더 이상 작업이 Executor 서비스에 제출되지 않음을 나타냅니다. 그런 다음 지정된 제한 시간(이 경우 1분)으로 waitTermination() 메서드를 호출합니다. 이 메서드는 모든 작업이 완료되거나 시간 초과에 도달할 때까지 현재 스레드를 차단합니다.
모든 작업이 시간 초과 전에 완료되면 종료 변수가 true로 설정되고, 그렇지 않으면 false로 설정됩니다. 그런 다음 완료된 값을 기반으로 필요한 유효성 검사 및 데이터베이스 저장 작업을 수행할 수 있습니다.
ExecutorService 및 waitTermination() 메서드를 활용하면 Java 프로그램의 모든 스레드가 작업을 완료할 때까지 효과적으로 기다릴 수 있습니다. 그런 다음 신청서의 후속 단계를 진행하세요.
위 내용은 Java 다중 스레드 응용 프로그램을 진행하기 전에 모든 스레드가 완료되었는지 어떻게 확인할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!