요약 이 기사에서는 Stream의 구현 원리를 살펴보고 Java 8 Stream의 오픈 소스 프레임워크 StreamEx를 사용하여 StackOverflow의 Java 8 Stream에 대해 자주 묻는 몇 가지 질문에 대답하는 방법을 소개합니다.
Convert Java 8 Listd94943c0b4933ad8cac500132f64757f
into Mapb56561a2c0bc639cf0044c0859afb88f
사용 JDK 스트림 API:
Map<String, Choice> result = choices.stream().collect(Collectors.toMap(Choice::getName, Function.identity()));
StreamEx API 사용:
Map<String, Choice> result = StreamEx.of(choices).toMap(Choice::getName);
Java 8 병렬 스트림의 사용자 정의 스레드 풀
JDK 스트림 API 사용:
ForkJoinPool forkJoinPool = new ForkJoinPool(2); forkJoinPool.submit(() -> //parallel task here, for example IntStream.range(1, 1_000_000).parallel().filter(PrimesPrint::isPrime).collect(toList()) ).get();
StreamEx API 사용:
IntStreamEx.range(1, 1_000_000).parallel(new ForkJoinPool(2)) .filter(PrimesPrint::isPrime).toList();
Java 8 속성별로 구별
JDK 스트림 API 사용:
public static <T> Predicate<T> distinctByKey(Function<? super T, ?> keyExtractor) { Set<Object> seen = ConcurrentHashMap.newKeySet(); return t -> seen.add(keyExtractor.apply(t)); } persons.stream().filter(distinctByKey(Person::getName));
StreamEx API 사용:
StreamEx.of(persons).distinctBy(Person::getName);
JDK 스트림 API 사용:
Stream.of(objects) .filter(Client.class::isInstance) .map(Client.class::cast) .map(Client::getID) .forEach(System.out::println);
StreamEx.of(objects) .select(Client.class) .map(Client::getID) .forEach(System.out::println);
관련 기사:
Java의 람다 표현식 및 스트림 클래스의 간단한 예 Miaowei Teahouse Javascript 실습 동영상 튜토리얼
위 내용은 Java 8 Stream 실무 요약 및 원리 적용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!