【浅谈Java的Predicate和Stream操作集合】(下)
什么是Stream?
Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据。 Stream(流)是一个来自数据源的元素队列并支持聚合操作。Stream并不会存放数据,而是按需计算。数据源 流的来源,可以是集合,数组,I/O channel, 产生器generator 等。
Stream常用中间方法
中间方法返回的是一个新的流
- filter(Predicate predicate):过滤Stream中所有不符合predicate的元素。
- mapToXxx(ToXxxFunction mapper):使用ToXxxFunction对流中的元素执行一对一的转换,该方法返回的新流中包含了ToXxxFUnction转换生成的所有元素。
- peek(Consumer action):依次对每个元素执行一些操作,该方法返的流与原有流包含的元素相同。
- distinct():该方法用于去除流中重复的元素(对于对象不行,因为new出来的对象的地址不同)
- sorted():保证流中的元素在后续的访问中处于有序的状态。
- limit(long maxSize):该方法保证对流的后续访问中最大允许的元素个数。
在 Java 8 中, 集合接口有两个方法来生成流:
stream() − 为集合创建串行流。
parallelStream() − 为集合创建并行流。
复制代码
public class Test {
public