티스토리 뷰

'Stream  연산을 처리하는 중에 하나의 결과를 통해 서로 다른 컬렉션 객체를 반환받을 수 있을까?' 라는 의문이 생겼습니다.

예시로 숫자 스트림 객체가 주어졌을 때, 짝수와 홀수 컬렉션을 한 번의 스트림 연산으로 가져오고 싶었던 것 입니다.

 

Stream patitioningBy 연산을 통해 가능하다고 하여 자세히 알아보게 되었습니다.

 

 

 


 

 

Stream partitioningBy

 

partitioningBy란?

Collectors.partitioningBy는 Java Stream API에서 주어진 조건(Predicate)에 따라 스트림 요소를 두 개의 그룹으로 나누기 위해 사용되는 메서드입니다. 이 메서드는 Collectors 클래스에서 제공되며, 각 요소가 조건을 만족하는지 여부에 따라 true 또는 false 키로 그룹을 나눕니다.

 

 

 

사용 방법

Collectors.partitioningBy(Predicate<? extends T> predicate);

이 메서드는 Predicate(참/거짓을 반환하는 조건식)을 인자로 받아, 해당 조건에 따라 스트림의 요소를 두 그룹으로 나눕니다.

 

 

예시

final Map<Boolean, List<Integer>> evenOddPartition = 
    Stream.of(1,2,3,4,5,6,7,8,9,10)
          .collect(Collectors.partitioningBy(n -> n % 2 == 0));
          
System.out.println("Even numbers: " + evenOddPartition.get(true));
System.out.println("Odd numbers: " + evenOddPartition.get(false));

'[개발] 언어 > Java' 카테고리의 다른 글

빈 스트림에 allMatch를 할 경우 true 반환  (0) 2024.10.27
Java 8 Parallel Stream  (0) 2024.09.19
Java Method  (1) 2023.11.11
Java Switch Case  (0) 2023.11.09
SOLID  (1) 2023.10.30