Java Parallel Stream
1. Java의 스트림 Java의 스트림은 데이터 소스를 둘러싼 단순한 래퍼이므로 편리한 방법으로 데이터에 대한 대량 작업을 수행할 수 있다. 데이터를 저장하지 않으며 기본 데이터 소스를 변경하지 않는다. 오히려 데이터 파이프라인에서 기능적 스타일 작업에 대한 지원을 추가한다. 1) 순차 스트림 기본적으로 Java의 모든 스트림 작업은 명시적으로 ...
1. Java의 스트림 Java의 스트림은 데이터 소스를 둘러싼 단순한 래퍼이므로 편리한 방법으로 데이터에 대한 대량 작업을 수행할 수 있다. 데이터를 저장하지 않으며 기본 데이터 소스를 변경하지 않는다. 오히려 데이터 파이프라인에서 기능적 스타일 작업에 대한 지원을 추가한다. 1) 순차 스트림 기본적으로 Java의 모든 스트림 작업은 명시적으로 ...
1. 주요 개념 Identity, Accumulator 및 Combiner Stream.reduce() 작업 사용 전에 작업의 참가자 요소를 별도의 블록으로 나눈다. 각자가 맡은 역할을 더 쉽게 이해할 수 있다. Identity - 축소 작업의 초기 값이자 스트림이 비어 있는 경우 기본 결과인 요소이다. Accumul...
1. 기본 아이디어 Stream은 Collection에서 쉽게 얻을 수 있는 요소의 시퀀스 이다. 맵은 순서 없이 키에서 값으로 매핑되는 다른 구조를 갖는다. 그러나 이것이 맵 구조를 다른 시퀀스로 변환하여 Stream API를 사용하여 자연스러운 방식으로 작업할 수 있다는 의미는 아니다. 맵에서 다양한 Collection을 얻고 이를 Stream...
1. 간단한 예 이름 스트림이 있고 이를 콘솔에 인쇄하려고 한다. peek()는 Consumer<T>를 유일한 인수로 기대하므로 적합해 보인다. Stream<String> nameStream = Stream.of("Alice", "Bob", "Chuck"); nameStream.peek(System.out::println); ...
1. Stream.reduce() 사용 Stream.reduce()는 stream의 요소를 축소하는 터미널 작업이다. 스트림의 각 요소에 이진 연산자(누산기)를 적용한다. 여기서 첫 번째 피연산자는 이전 애플리케이션의 반환 값이고 두 번째 피연산자는 현재 스트림 요소이다. reduce() 메서드를 사용하는 첫 번째 방법에서 accumulator 함...
1. Stream.filter() 사용 filter() 메소드는 주어진 Predicate와 일치하는 스트림 요소를 필터링할 수 있는 Stream 인터페이스의 중간 작업이다. Stream<T> filter(Predicate<? super T> predicate) 어떻게 작동하는지 확인하기 위해 Customer 클래스를 만든다....
1. 기본 예시 간단한 조건자를 사용하여 이름 목록을 필터링하는 방법이다. @Test public void whenFilterList_thenSuccess(){ List<String> names = Arrays.asList("Adam", "Alexander", "John", "Tom"); List<String> res...
1. forEach() 내의 if/else 로직 먼저 Integer List를 만든 다음 정수 스트림 forEach() 메서드 내에서 기존 if/else 논리를 사용한다. List<Integer> ints = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10); ints.stream() .forEach...
1. Spliterator API 1) tryAdvance 이는 시퀀스를 단계별로 실행하는데 사용되는 주요 방법이다. 이 메소드는 Spliterator의 요소를 하나씩 순차적으로 소비하는데 사용되는 소비자를 취하고, 순회할 요소가 없으면 false를 반환한다. 여기서는 요소를 순회하고 분할하는데 이를 사용하는 방법이다. 먼저 35000개의 기사가...
1. Stream Takewhile/Dropwhile 메서드에 대한 토론은 StackOverflow에서 반복적으로 나타났다 (가장 인기 있는 것은 이 메서드 이다). 이 Stream의 현재 값 길이가 10 보다 작아질 때까지 이전 Stream의 값에 문자 하나를 추가하여 String의 Stream을 생성한다고 가정한다. Java 8에서는 실제로 다...