Java8的Stream如何使用(java,stream,开发技术)

时间:2024-05-03 16:42:56 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    Java8%E7%9A%84Stream%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8

Stream(流)是一个来自数据源的元素队列并支持聚合操作

Java中的Stream并不会存储元素,而是按需计算。 数据源 流的来源。 可以是集合,数组,I/O channel, 产生器generator 等。

聚合操作 类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。 和以前的Collection操作不同,Stream操作还有两个基础的特征如下:

Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风格。 这样做可以对操作进行优化, 比如延迟执行和短路。

内部迭代: 以前对集合遍历都是通过Iterator或者For-Each的方式, 显式的在集合外部进行迭代, 这叫>做外部迭代。 Stream提供了内部迭代的方式, 通过访问者模式(Visitor)实现。

中间操作常用方法有:筛选:filter 映射:map 排序:sorted提取与组合 收集:collect。

终止操作:遍历:foreach 匹配:find、match 规约:reduce 聚合:max、min、count。

Optional findFirst();

Optional findAny();

boolean allMatch(Predicate<? super T> predicate);

boolean anyMatch(Predicate<? super T> predicate);

boolean noneMatch(Predicate<? super T> predicate);

基本使用 Stream流中的Match相关方法使用代码如:

public static Collector<T, ?, List> toList():转换为List集合。

public static Collector<T, ?, Set> toSet():转换为Set集合。

public static <T, K, U> Collector<T, ?, Map<K,U>> toMap(Function<? super T, ? extends K> keyMapper, Function<? super T, ? extends U> valueMapper):转换为Map集合。

本文:Java8的Stream如何使用的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:java如何拆解字节码文件下一篇:

9 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18