티스토리 뷰
01 : 반복에서 스트림 연산으로
컬렉션을 처리할 때 보통은 요소들을 순회하며 값에 접근한다. 예를 들면 책에서 모든 긴 단어의 수를 고려하는 예제를 살펴보자
1 2 3 | String contents = new String(Files.readAllBytes( Paths.get("alice.txt")), StandardCharsets.UTF_8); List<String> words = Arrays.asList(contents.split("[\\P{L}]+")); |
"alice.txt"에 있는 단어를 words 리스트에 넣었다.
1 2 3 4 | int count = 0; for(String w : words){ if(w.length() > 12) count++; } |
단어의 길이가 12이상인 단어의 개수를 세는 전통적인 순회 방식이다. 하지만 이 순회 방식은 코드를 병렬화하기 어렵다는 단점이 있다. 이제 여기서 자바 8의 벌크 연산이 등장 한다.
1 | long count = words.stream().filter(w -> w.length() > 12).count(); |
stream 메서드는 words 리스트의 스트림을 돌려준다. filter 메서드는 12글자 보다 긴 단어만 담는 다른 스트림을 리턴 한다. count 메서드는 이 스트림을 결과로 리듀스 한다.
'Language > Java' 카테고리의 다른 글
[JAVA8] 람다 표현식 (0) | 2017.01.29 |
---|---|
[JAVA8] 람다 표현식 (0) | 2017.01.29 |
[JAVA8] 람다 표현식 (0) | 2017.01.24 |
[JAVA8] 람다 표현식 (0) | 2017.01.24 |
[JAVA8] 람다 표현식 (0) | 2017.01.18 |