Java8新特性:利用Stream的操作数据源,集合,数组等使用场景。再也不怕面试官问新特性

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		-- 返回流中最小值

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值