ホームページ  >  記事  >  Java  >  Java 8 Stream の実践的な概要と原則的な応用

Java 8 Stream の実践的な概要と原則的な応用

php是最好的语言
php是最好的语言オリジナル
2018-07-27 09:22:232021ブラウズ

概要 この記事では、Stream の実装原理を検討し、Java 8 Stream のオープンソース フレームワーク StreamEx を使用して、StackOverflow 上の Java 8 Stream に関するよくある質問に答える方法を紹介します。 JDK Stream 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);

    Listd94943c0b4933ad8cac500132f64757f into Mapb56561a2c0bc639cf0044c0859afb88f

    Java 8並列ストリームのカスタムスレッドプール

JDK Stream 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 Stream 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);
  • Java 8でストリームをキャストすることは可能ですか?

JDK Stream APIを使用する:

Stream.of(objects)
    .filter(Client.class::isInstance)
    .map(Client.class::cast)
    .map(Client::getID)
    .forEach(System.out::println);

StreamEx APIを使用する:
    StreamEx.of(objects)
        .select(Client.class)
        .map(Client::getID)
        .forEach(System.out::println);
  • 関連記事:

  • Java の Lambda 式と Stream クラスの簡単な例

関連動画:

Miaowei Teahouse Javascript 実践ビデオチュートリアル

以上がJava 8 Stream の実践的な概要と原則的な応用の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。