【浅谈Java的Predicate和Stream操作集合】

【浅谈Java的Predicate和Stream操作集合】(下)

什么是Stream?

Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据。 Stream(流)是一个来自数据源的元素队列并支持聚合操作。Stream并不会存放数据,而是按需计算。数据源 流的来源,可以是集合,数组,I/O channel, 产生器generator 等。

Stream常用中间方法

中间方法返回的是一个新的流

  1. filter(Predicate predicate):过滤Stream中所有不符合predicate的元素。
  2. mapToXxx(ToXxxFunction mapper):使用ToXxxFunction对流中的元素执行一对一的转换,该方法返回的新流中包含了ToXxxFUnction转换生成的所有元素。
  3. peek(Consumer action):依次对每个元素执行一些操作,该方法返的流与原有流包含的元素相同。
  4. distinct():该方法用于去除流中重复的元素(对于对象不行,因为new出来的对象的地址不同)
  5. sorted():保证流中的元素在后续的访问中处于有序的状态。
  6. limit(long maxSize):该方法保证对流的后续访问中最大允许的元素个数。

在 Java 8 中, 集合接口有两个方法来生成流:

stream() − 为集合创建串行流。

parallelStream() − 为集合创建并行流。
复制代码
public class Test {
	public
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值