블로그

Stream이란? 기본 개념과 특징 (JAVA)

Stream이란? 기본 개념과 특징 (JAVA)

What is Java Stream

아이디어가 있나요?

Hitek 언제나 당신과 동행할 준비가 되어있습니다.​

Java에서 Stream은 데이터 처리 연산을 지원하는 강력한 API로, 컬렉션, 배열, I/O 소스 등의 요소를 선언적이고 효율적으로 다룰 수 있게 해줍니다. 함수형 프로그래밍 스타일을 도입하여 코드의 가독성과 유지보수성을 높이며, 병렬 처리도 간편하게 구현할 수 있습니다.

이 글에서는 Java Stream의 기본 개념, 주요 특징, 활용 방법을 쉽게 설명하고, 실제 예제를 통해 어떻게 효율적으로 사용할 수 있는지 알아보겠습니다.


1. Stream의 기본 개념

✔ Stream이란?

Java 8부터 도입된 Stream컬렉션, 배열 등의 데이터 소스를 처리하기 위한 추상화된 연산 집합입니다. 기존의 반복문(for, while)을 대체할 수 있으며, 람다 표현식(Lambda Expressions)과 함께 사용해 코드를 간결하게 작성할 수 있습니다.

Stream은 크게 두 가지로 구분됩니다:

  • 중간 연산(Intermediate Operations): filter(), map(), sorted() 등 데이터를 변환하거나 필터링합니다.
  • 최종 연산(Terminal Operations): forEach(), collect(), reduce() 등 결과를 도출하거나 저장합니다.
List<String> names = Arrays.asList("Alice", "Bob", "Charlie");  
names.stream()  
     .filter(name -> name.startsWith("A")) // 중간 연산  
     .forEach(System.out::println);         // 최종 연산

✔ Stream vs. 컬렉션(Collection)

특징 Stream 컬렉션(Collection)
데이터 저장 저장하지 않음 데이터를 저장
연산 방식 지연 평가(Lazy Evaluation) 즉시 평가(Eager Evaluation)
재사용 가능 불가능 (1회용) 가능
병렬 처리 parallelStream()으로 간단히 구현 직접 구현 필요

Stream은 데이터를 직접 저장하지 않고, 원본 데이터를 읽어 연산을 수행합니다. 또한, 지연 평가(Lazy Evaluation)를 사용해 필요한 시점에만 연산을 실행합니다.


2. Stream의 주요 특징

(1) 선언형 프로그래밍 지원

Stream은 “무엇을 할 것인가(What)”에 집중합니다. 반복문은 “어떻게 할 것인가(How)”를 명시해야 하지만, Stream은 원하는 결과를 선언하면 내부적으로 처리합니다.

// 기존 방식 (How)  
for (String name : names) {  
    if (name.length() > 3) {  
        System.out.println(name);  
    }  
}  

// Stream 방식 (What)  
names.stream()  
     .filter(name -> name.length() > 3)  
     .forEach(System.out::println);

(2) 병렬 처리(Parallel Processing) 간소화

parallelStream()을 사용하면 멀티 스레드 환경에서 데이터를 분할 처리할 수 있습니다.

List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);  
int sum = numbers.parallelStream()  
                 .mapToInt(Integer::intValue)  
                 .sum();  
System.out.println("합계: " + sum);

(3) 불변성(Immutable)과 1회용

Stream은 원본 데이터를 변경하지 않으며, 한 번 사용하면 재사용할 수 없습니다.

Stream<String> stream = names.stream();  
stream.forEach(System.out::println);  
// stream.forEach(...); → Error: 스트림이 이미 소비됨

3. Stream의 주요 연산

✔ 중간 연산 (Intermediate Operations)

  • filter(Predicate): 조건에 맞는 요소만 필터링
  • map(Function): 요소를 변환 (예: 문자열 → 길이)
  • sorted(): 정렬
  • distinct(): 중복 제거
List<Integer> numbers = Arrays.asList(1, 2, 3, 2, 4);  
numbers.stream()  
      .filter(n -> n % 2 == 0)  // 짝수만 필터링  
      .map(n -> n * 2)           // 2배 증가  
      .distinct()                // 중복 제거  
      .forEach(System.out::println);

✔ 최종 연산 (Terminal Operations)

  • forEach(Consumer): 각 요소에 작업 수행
  • collect(Collector): 결과를 컬렉션으로 변환
  • reduce(): 요소를 결합 (예: 총합 계산)
  • count(): 요소 개수 반환
List<String> result = names.stream()  
                          .filter(name -> name.length() > 3)  
                          .collect(Collectors.toList());  
System.out.println(result); // [Alice, Charlie]

4. Stream 활용 예제

✔ 조건에 맞는 데이터 필터링

List<Product> products = Arrays.asList(  
    new Product("Laptop", 1200),  
    new Product("Phone", 800),  
    new Product("Tablet", 500)  
);  

List<Product> expensiveProducts = products.stream()  
                                        .filter(p -> p.getPrice() > 1000)  
                                        .collect(Collectors.toList());

✔ 데이터 변환 및 정렬

List<String> cities = Arrays.asList("Seoul", "Busan", "Incheon");  
List<String> sortedCities = cities.stream()  
                                 .sorted()  
                                 .map(String::toUpperCase)  
                                 .collect(Collectors.toList());

✔ 병렬 스트림으로 성능 향상

long count = products.parallelStream()  
                    .filter(p -> p.getPrice() > 500)  
                    .count();

5. Stream 사용 시 주의사항

  • 재사용 불가: 한 번 사용한 Stream은 다시 사용할 수 없습니다.
  • 지연 평가: 중간 연산은 최종 연산이 호출될 때 실행됩니다.
  • 성능 고려: 간단한 연산은 for문이 더 빠를 수 있습니다.

마치며

Java의 Stream API는 데이터 처리 방식을 혁신적으로 바꿨습니다. 람다 표현식과 결합해 코드를 간결하게 만들고, 병렬 처리를 쉽게 구현할 수 있어 현대적인 Java 개발에 필수적입니다.

Stream을 제대로 활용하면 가독성 높은 코드효율적인 데이터 처리를 동시에 얻을 수 있습니다. 이제 여러분의 프로젝트에서 Stream을 적용해보세요!

💡 더 알아보기

“어떤 데이터 처리 작업을 Stream으로 바꿔볼까요?” 💬 댓글로 여러분의 생각을 공유해주세요!

Picture of Khoi Tran

Khoi Tran

Khoi Tran은 하이텍 소프트웨어의 소유자입니다. 사회의 문제를 해결하기 위해 기술적인 솔루션을 기여하는 것에 열정적입니다. 소프트웨어 엔지니어로 6년간 근무한 기술 지식과 (2018년부터 기술 회사를 운영하며) 비즈니스 감각을 갖추고 있어, 나는 다행히도 이 디지털 세계에서 더 많은 장점을 가진 현대적인 기업가 세대의 일부로 위치하고 있습니다.
기타 기사
Overseas development manpower

글로벌 경쟁력 낮추는 개발자 부족, 해외로 눈 돌려야

한국의 IT 산업은 빠르게 성장하고 있지만, 개발자 부족 문제가 심각해지면서 글로벌 경쟁력이 위협받고 있다. 정부와 기업들은 국내 인재 양성에 집중하고 있지만, 수요를 따라잡지 못하는 상황이다. 이제는 해외 개발자 영입을 적극적으로 검토해야 할 때다. 한국 IT 산업의 숨은 위협, 개발자 수급 불균형 최근 한국은 소프트웨어 및 AI 분야에서 두각을 나타내고 있지만, 핵심 인력인 개발자의 부족이 발목을

세부정보 →
What is ETL

ETL(Extract, Transform, Load)이란: 데이터 통합의 핵심 기술

데이터는 현대 비즈니스의 핵심 자원입니다. 하지만 원시 데이터 그대로는 유용하지 않습니다. 이를 의미 있는 정보로 변환하는 과정이 필요합니다. 이때 등장하는 기술이 바로 ETL(Extract, Transform, Load)입니다. ETL은 데이터 웨어하우스 구축, 비즈니스 인텔리전스(BI), 데이터 분석 등 다양한 분야에서 필수적인 역할을 합니다. 이 글에서는 ETL의 개념, 작동 방식, 그리고 실제 적용 사례를 통해 데이터 통합의 핵심 기술을 파헤쳐

세부정보 →
ai expo

AI EXPO KOREA 2025: 인공지능의 미래를 만나다

한국은 오랫동안 기술과 혁신의 글로벌 리더로 자리매김해 왔으며, AI EXPO KOREA 2025는 그 명성을 한층 더 공고히 할 예정입니다. 올해 가장 기대되는 기술 행사 중 하나로, 이 엑스포는 산업 리더, 스타트업, 연구자, AI 애호가들이 한자리에 모여 인공지능의 최신 발전을 탐구할 것입니다. 기술 전문가, 투자자, 또는 단순히 AI에 관심이 있는 분이라면, 이 행사는 분명 게임 체인저가

세부정보 →
ai illustrator

어도비 일러스트레이터 (Adobe Illustrator): 디자이너를 위한 궁극의 벡터 툴

디지털 아트, 로고 디자인, 타이포그래피부터 인포그래픽까지—어도비 일러스트레이터(Adobe Illustrator)는 창의적인 작업을 위한 필수 도구다. 벡터 기반의 정밀한 디자인이 필요한 전문가들에게 이 프로그램은 단순한 소프트웨어가 아니라 예술적 표현의 확장이다. 이 글에서는 Illustrator의 핵심 기능, 최신 업데이트, 그리고 한국 디자이너들을 위한 활용 팁까지 깊게 알아본다. 1. 어도비 일러스트레이터란? Adobe Illustrator는 1987년 출시된 벡터 그래�스 편집 소프트웨어로, 확대해도 깨지지

세부정보 →
game app development

모바일 게임 개발 구축 방법: 성공적인 출시를 위한 필수 가이드

모바일 게임 시장은 급성장 중이며, 2024년 기준 전 세계 모바일 게임 시장 규모는 1,000억 달러를 넘어섰습니다. 이처럼 경쟁이 치열한 환경에서 성공적인 게임을 개발하려면 체계적인 접근이 필요합니다. 이 글에서는 모바일 게임 개발 구축 방법을 단계별로 설명하며, 초보자부터 전문가까지 활용할 수 있는 실용적인 팁을 제공합니다. 1. 모바일 게임 개발의 핵심 단계 모바일 게임 개발은 아이디어 구상부터 출시

세부정보 →
JPA vs Mybatis

MyBatis와 JPA의 차이, JPA를 선택한 이유는?

Java 백엔드 개발을 하다 보면 MyBatis와 JPA라는 두 가지 주요 데이터 접근 기술을 마주하게 됩니다. 둘 다 장단점이 뚜렷하지만, 최근 들어 JPA가 더 많이 선택되고 있는 추세입니다. 왜 그럴까요? 이 글에서는 MyBatis와 JPA의 핵심 차이점을 비교하고, 왜 많은 개발자들이 JPA를 선호하는지 그 이유를 분석해보겠습니다. 1. MyBatis vs. JPA: 기본 개념 비교 MyBatis: SQL 중심의 데이터

세부정보 →
Scroll to Top