Stream

什么是Stream

是数据渠道,像类似流水线的方法处理数据。

特点:

  • Stream 自己不会存储元素。只负责处理数据。
  • Stream 不会改变源对象。相反,他们会返回一个持有结果的新Stream。
  • Stream 操作是延迟执行的。这意味着他们会等到需要结果的时候才执行。

三大步骤

一. 创建Stream。一个数据源(如:集合、数组)

  • 通过Collection:stream()

  • 通过Arrays的静态方法: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)

二.中间操作。对数据源的数据进行处理

  • 筛选

filter(Predicate p)。接收 Lambda , 从流中排除某些元素。

distinct()。筛选,通过流所生成元素的 hashCode() 和 equals() 去除重复元素。

limit(long maxSize)。截断流,使其元素不超过给定数量

skip(long n)。跳过元素,返回一个扔掉了前 n 个元素的流。若流中元素不足 n 个,则返回一个空流。与 limit(n) 互补

  • 映 射

map(Function f)。接收一个函数作为参数,该函数会被应用到每个元素上,并将其映射成一个新的元素。

Stream<Integer> boxed()。包装为Integer类。把 IntStream 流对象转换成 Stream<Integer> 对象

  • 排序

sorted()。产生一个新流,其中按自然顺序排序。

sorted(Comparator com)。产生一个新流,其中按比较器顺序排序

三.终止操作。一旦执行终止操作,就执行中间操作链,并产生结果。之后,不会再被使用

  • 匹配与查找

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>

  • 收集

collect(Collector c)。将流转换为其他形式。接收一个 Collector接口的实现,用于给Stream中元素做汇总的方法

List<Employee> emps= list.stream().collect(Collectors.toList());
Set<Employee> emps= list.stream().collect(Collectors.toSet());Collection<Employee> emps =list.stream().collect(Collectors.toCollection(ArrayList::new));
Collection<Employee> emps =list.stream().collect(Collectors.toCollection(ArrayList::new));

一个例子:int[]->list

import java.util.stream.*;//导入包,Collectors所在的包
import java.util.*;//Arrays所在的包

//1.创建int数组
int[] ints = {1, 2, 3};
//2.调用 Arrays 类的静态方法 Stream() 把 ints 数组对象转换成流,这里要注意需要使用 boxed() 方法把IntStream 流转化成 Stream 流,因为转化成 Stream 流之后才能调用 collect() 收集方法获得List
List<Integer> intList = Arrays.stream(ints).boxed().collect(Collectors.toList());
//3.最后打印输出,这里使用到了 Lambda 表达式和方法引用
intList.forEach(System.out::println);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值