Stream介绍
操作数据源–集合,数组等
可以对数据源进行一系列流水线的操作–>产生一个新流,而且原数据不会有任何改变
stream的特点:
1.stream不会存储任何元素
2.stream不改变源对象,返回一个持有结果的新stream
3.stream操作是延迟执行的,意味着等到需要结果的时候才会执行
步骤:
创建stream -> 中间操作 -> 终止操作(如果不进行终止操作前面两步操作无效,终止操作可以是打印,可以是collect方法等)
创建stream的方式
第一种方式 : 通过Collection系列提供stream() 或者 parallelStream()
第二种方式 : 通过Arrays中的静态方法stream()
创建一个实体类:
第三种方式 : Stream类中的静态方法of()
第四种方式 : 创建无限流
结果:无限输出,可以通过limit(int it)方法进行限制
使用场景:可以利用无限流加limit()方法的形式,生成随机数
这样的方法比Java8以前的方法容易很多
--生成
Stream.generate(() -> Math.random())
.limit(5)
.forEach(System.out::println);
stream的中间操作
概念:简单理解为SQL语句中的where,进行条件筛选
中间操作都有如下:
filter – 过滤,接收一个lamda,从中排除元素
limit – 截断,使元素不超过给定数量
skip – 跳过元素,返回一个扔掉了前n个元素的流,如果流中不足n个,返回一个空流
skip操作与limit互补
distinct – 筛选,通过流产生的元素的hashCode()和equals()去除重复元素
举个例子:
但在这里值得注意的是:
多个中间操作可以链接起来形成一个流水线,除非流水线上触发中止操作,否则中间操作不会做任何处理,而在终止操作时一次性进行处理,称为惰性求值
换句话说,必须做中止操作,流才会有结果
还有以下的中间操作:
map – 将元素转换成其他形式或者提取信息,接收一个函数作为参数,该函数会被应用到元素上,将其映射为一个新的元素
stream的排序
sorted(Comparable) 自然排序
sorted(Comparator com) 定制排序
Stream的终止操作
查找与匹配
allMatch -- 检查是否匹配使有元素
anyMatch -- 检查是否至少匹配一个元素
noneMatch -- 检查是否没有匹配所有元素 / 有匹配的元素
findFirst -- 返回第一个元素
findAny -- 返回当前流中的任意元素
count -- 返回流中元素总个数
max -- 返回流中最大值
min -- 返回流中最小值