본문 바로가기
728x90

ExecutorService2

[JAVA] 비동기 프로그래밍의 완성 : Callable과 Future 인터페이스 심층 분석 자바 멀티쓰레딩의 세계에서 Runnable은 가장 오래된 친구와 같습니다. 하지만 Runnable에는 치명적인 단점이 하나 있습니다. 바로 작업을 수행한 뒤 그 '결과값'을 반환할 수 없고, 체크 예외(Checked Exception)를 던질 수도 없다는 점입니다. 이러한 한계를 극복하고 현대적인 비동기 처리 모델을 완성하기 위해 JDK 5부터 도입된 것이 바로 Callable과 Future입니다. 이 글에서는 단순히 두 인터페이스의 정의를 넘어, 왜 우리가 실무에서 이들을 사용해야 하는지, 그리고 비동기 연산의 결과를 어떻게 안전하게 수확할 수 있는지 전문가의 관점에서 상세히 설명하겠습니다.1. Callable과 Future: 비동기 작업의 주문과 영수증Callable과 Future의 관계는 식당에서의.. 2026. 1. 21.
[JAVA] 자바 성능 최적화의 열쇠 : 쓰레드 풀(Thread Pool)과 ExecutorService 완벽 가이드 현대적인 서버 사이드 애플리케이션에서 수많은 요청을 동시에 처리하는 능력은 필수적입니다. 자바 개발자가 멀티쓰레딩을 구현할 때 가장 먼저 배우는 것은 new Thread()이지만, 실제 운영 환경에서 이 방식을 사용하는 것은 매우 위험할 수 있습니다. 무분별한 쓰레드 생성은 메모리 부족(OOM)과 컨텍스트 스위칭 오버헤드로 인해 시스템을 마비시킬 수 있기 때문입니다. 이러한 문제를 우아하게 해결해주는 것이 바로 쓰레드 풀(Thread Pool)과 이를 관리하는 ExecutorService입니다. 본 포스팅에서는 자바의 동시성 프레임워크인 java.util.concurrent 패키지를 중심으로, 효율적인 쓰레드 관리 기법을 심층적으로 다루어 보겠습니다.1. 쓰레드 풀(Thread Pool)의 개념과 도입 .. 2026. 1. 21.
728x90