ExecutorService 인터페이스는 Executor의 확장된 버전입니다. 스레드의 생명 주기에 대한 메서드가 있어서 스레드 관리를 훨씬 더 편리하게 제공합니다. ExecutorService 메서드 shutdown : 이전에 제출된 작업은 순차적으로 실행되면서 종료됩니다. 새로운 작업은 허용하지 않습니다. 이전에 제출된 작업이 실행은 되지만 완료할 때까지는 기다리지 않습니다. shutdownNow : 이전에 제출된 작업이 실행되지 않고 바로 종료되면서 가지고 있던 작업 목록을 반환합니다. shoutdown과 마찬가지로 실행 중인 작업이 종료될 때까지 기다리지 않습니다. isShutdown : ExecutorService가 shutdown 상태이면 true 아니면 false를 반환합니다. isTermi..
Executor 인터페이스는 명시적으로 스레드를 생성하는 대신에 사용됩니다. 일반적으로 호출자 스레드가 아닌 다른 스레드에서 실행이 됩니다. Executor 인터페이스는 스레드를 관리하고 작업을 스레드에 할당하는 기본적인 인터페이스입니다. Executor는 작업 실행 및 관리를 담당하며, 다양한 작업 큐 및 스레드 풀 구현을 허용하여 애플리케이션에서 비동기적으로 작업을 수행할 수 있게 해줍니다. Executor 기본 예시 public class Main { public static void main(String[] args) { Task task = new Task(); for(int i = 0; i < 10 ; i++) { task.execute(new RunThread()); } } static cl..
스레드 풀의 개념 병렬 처리가 많아지면 스레드의 생성 및 스케줄링에 메모리 사용량이 늘어납니다. 스레드 풀은 다수의 스레드를 미리 생성하여 특정 작업을 수행할 때 이용하는 기법으로, 이를 통해 스레드의 생성 및 스케줄링에 따른 메모리를 줄이고 효율적인 작업 관리를 할 수 있습니다. 이는 다수의 클라이언트 요청이 동시에 들어올 때, 서버에서 각 요청을 스레드로 처리해야 하는 상황에서 특히 중요합니다. 스레드 풀 구성요소 스레드 : 작업을 수행하는 단위 작업 큐 : 스레드 풀로 보내지는 작업들을 저장하는 공간 작업(태스크) : 스레드가 수행해야 될 작업 스레드 풀 동작방식 클라이언트가 작업을 스레드 풀에 제출하면 스레드 풀 작업 큐에 저장됩니다. 스레드 풀 내의 생성된 스레드들이 작업 큐에서 작업을 가져와 ..