티스토리 뷰
Stream
- Stream은 데이터를 담고 있는 저장소(컬렉션)가 아니다.
- Functional in nature, 스트림이 처리하는 데이터 소스를 변경하지 않는다.
- 스트림으로 처리하는 데이터는 오직 한번만 처리한다.
- 무제한일 수도 있다. (Short Circuit 메소드를 사용해서 제한할 수 있다.)
- 중개 오퍼레이션은 근본적으로 lazy하다.
- 손쉽게 병렬 처리할 수 있다.
- .parallelStream()을 사용하면 JVM이 병렬처리
- parallelStream을 사용한다고 무조건 빨라지는 것이 아니니 적절히 사용해야함
스트림 파이프 라인
- 0 또는 다수의 중개 오퍼레이션 (intermediate operation)과 한개의 종료 오퍼레이션 (terminal operation)으로 구성한다.
- 스트림의 데이터 소스는 오직 터미널 오퍼레이션을 실행할 때에만 처리한다.
중개 오퍼레이션
- Stream을 리턴한다.
- Stateless / Stateful 오퍼레이션으로 더 상세하게 구분할 수도 있다. (대부분 Stateless지만 distinct나 sorted 처럼 이전 소스 데이터를 참조해야하는 오퍼레이션은 Stateful 오퍼레이션이다.)
- filter, map, limit, skip, sorted …
종료 오퍼레이션
- Stream을 리턴하지 않는다.
- collect, allMatch, count, forEach, min, max …
참고
- https://docs.oracle.com/javase/8/docs/api/java/util/stream/package-summary.html
- https://docs.oracle.com/javase/8/docs/api/java/util/stream/Stream.html
List<String> names = new ArrayList<>();
names.add("test");
names.add("eerojwqoe");
names.add("wqesdifnas");
names.add("eiorewer");
List<String> collect = names.stream().map((s) -> {
System.out.println(s);
return s.toUpperCase();
}).collect(Collectors.toList());
collect.forEach(System.out::println);
//원본 names는 변경되지 않았다
names.forEach(System.out::println);
728x90
'헉!! > jsp, java' 카테고리의 다른 글
[Java] Optional (0) | 2024.07.20 |
---|---|
[Java] Functional Interface 와 Lambda (0) | 2024.07.20 |
[JAVA] pdfbox 텍스트 구분자 넣기 (0) | 2020.11.21 |
[JAVA] PDF to XLS (0) | 2020.04.09 |
[JAVA] PDF 파일 텍스트 읽기 (0) | 2020.04.09 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- JavaScript
- zero
- jQuery
- Programming
- Object C
- Java
- iBATIS
- 티스토리챌린지
- MySQL
- 오브젝트 C
- iPhone
- JSP
- Spring
- 오브젝티브 C
- 아이폰 어플리케이션
- IT
- Spring Framework
- Objective-C
- 제이쿼리
- SQL
- 오블완
- iOS 개발
- 자바
- 아이폰 개발
- 아이폰
- MAC OSX 10.7
- oracle
- 자바스크립트
- tomcat
- Objective C
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
글 보관함