1、简介Streamjava
Java8中有两大最为重要的改变。第一个是 Lambda 表达式;另一 个则是 Stream API(java.util.stream.*)。Stream 是 Java8 中处理集合的关键抽象概念,它能够指定你但愿对集合进行的操做,能够执行很是复杂的查找、过滤和映射数据等操做。使用Stream API 对集合数据进行操做,就相似于使用 SQL 执行的数据库查询。也可使用 Stream API 来并行执行操做。简而言之,Stream API 提供了一种高效且易于使用的处理数据的方式。
2、什么是Stream
流(Stream) 究竟是什么呢?
是数据渠道,用于操做数据源(集合、数组等)所生成的元素序列。“集合讲的是数据,流讲的是计算!”git
注意:github
(1)Stream 本身不会存储元素。
(2)Stream 不会改变源对象。相反,他们会返回一个持有结果的新Stream。数组
(3)Stream 操做是延迟执行的。这意味着他们会等到须要结果的时候才执行。网络
3、Stream 的操做三个步骤ide
No.1 Stream函数
一、建立 Streamspa
一个数据源(如:集合、数组),获取一个流对象
Java8 中的 Collection 接口被扩展,提供了 两个获取流的方法:
default Stream<E> stream() : 返回一个顺序流
default Stream<E> parallelStream() : 返回一个并行流排序
二、由数组建立流
Java8 中的 Arrays 的静态方法 stream() 可 以获取数组流:
static <T> Stream<T> stream(T[] array): 返回一个流
重载形式,可以处理对应基本类型的数组:
public static IntStream stream(int[] array)
public static LongStream stream(long[] array)
public static DoubleStream stream(double[] array)
三、由值建立流
可使用静态方法 Stream.of(), 经过显示值 建立一个流。它能够接收任意数量的参数。
public static<T> Stream<T> of(T... values) : 返回一个流
四、由函数建立流:建立无限流
可使用静态方法 Stream.iterate() 和 Stream.generate(), 建立无限流。迭代
public static<T> Stream<T> iterate(final T seed, final UnaryOperator<T> f)
生成
public static<T> Stream<T> generate(Supplier<T> s) :
No.2 Stream
一、中间操做
一个中间操做链,对数据源的数据进行处理
二、Stream 的中间操做
多个中间操做能够链接起来造成一个流水线,除非流水 线上触发终止操做,不然中间操做不会执行任何的处理! 而在终止操做时一次性所有处理,称为“惰性求值”。
筛选与切片
方法 | 描述 |
filter(Predicate p) | 接收 Lambda , 从流中排除某些元素。 |
distinct() | 筛选,经过流所生成元素的 hashCode() 和 equals() 去 除重复元素 |
limit(long maxSize) | 截断流,使其元素不超过给定数量。 |
skip(long n) | 跳过元素,返回一个扔掉了前 n 个元素的流。若流中元素 不足 n 个,则返回一个空流。与 limit(n) 互补 |
代码:点击这里
映射
方法 | 描述 |
map(Function f) | 接收一个函数做为参数,该函数会被应用到每一个元 素上,并将其映射成一个新的元素。 |
mapToDouble(ToDoubleFunction f) | 接收一个函数做为参数,该函数会被应用到每一个元 素上,产生一个新的 DoubleStream。 |
mapToInt(ToIntFunction f) | 接收一个函数做为参数,该函数会被应用到每一个元 素上,产生一个新的 IntStream。 |
mapToLong(ToLongFunction f) | 接收一个函数做为参数,该函数会被应用到每一个元 素上,产生一个新的 LongStream。 |
flatMap(Function f) | 接收一个函数做为参数,将流中的每一个值都换成另 一个流,而后把全部流链接成一个流 |
三、排序
方法 | 描述 |
sorted() | 产生一个新流,其中按天然顺序排序 |
sorted(Comparator comp) | 产生一个新流,其中按比较器顺序排序 |
一个终止操做,执行中间操做链,并产生结果
二、终端操做会从流的流水线生成结果。其结果能够是任何不是流的 值,例如:List、Integer,甚至是 void 。
查找与匹配
方法 | 描述 |
allMatch(Predicate p) | 检查是否匹配全部元素 |
anyMatch(Predicate p) | 检查是否至少匹配一个元素 |
noneMatch(Predicate p) | 检查是否没有匹配全部元素 |
findFirst() | 返回第一个元素 |
findAny() | 返回当前流中的任意元素 |
count() | 返回流中元素总数 |
max(Comparator c) | 返回流中最大值 |
min(Comparator c) | 返回流中最小值 |
forEach(Consumer c) | 内部迭代(使用 Collection 接口须要用户去作迭 代,称为外部迭代。相反,Stream API 使用内部 迭代——它帮你把迭代作了) |
归约
reduce(T iden, BinaryOperator b) | 能够将流中元素反复结合起来,获得一个值。 返回 T |
reduce(BinaryOperator b) | 能够将流中元素反复结合起来,获得一个值。 返回 Optional<T> |
备注:
map 和 reduce 的链接一般称为 map-reduce 模式,因 Google 用它 来进行网络搜索而出名。
收集
方法 | 描述 |
collect(Collector c) | 将流转换为其余形式。接收一个 Collector接口的 实现,用于给Stream中元素作汇总的方法 |
Collector 接口中方法的实现决定了如何对流执行收集操做(如收集到 List、Set、Map)。可是 Collectors 实用类提供了不少静态方法,能够方便地建立常见收集器实例。