Java 8 Stream(四、Stream终端操作:forEach()、*Match、find*()、max、min()、reduce()、collect()、toArray()、count())

本文详细介绍了Java 8 Stream的终端操作,包括遍历(forEach、forEachOrdered)、匹配(anyMatch、noneMatch、allMatch)、聚合(findAny、findFirst、max、min)、规约(reduce)和收集(collect、toArray、count)等,结合实例解析了每个操作的用法和特点。
摘要由CSDN通过智能技术生成

上文我们已经介绍了Stream中间操作,没看过的同学请出门左转 Java 8 Stream(三、Stream中间操作:filter()、distinct()、skip()、limit()、map()、flatMap()、sorted()、peek())



本文我们主要介绍Stream终端操作(Terminal operations)。

一、分类

根据对元素的处理方式,终端操作可分为短路操作(short-circuiting)和非短路操作(non-interfering)。
短路操作: 类似 || 操作符,遇到某些符合条件的元素就可以得到最终结果。短路操作包括anyMatch()、noneMatch()、allMatch()、findAny()、findFirst()。
非短路操作: 类似 && 操作符,必须处理所有元素才能得到最终结果。

二、介绍

(一)遍历

1、forEach()

void forEach(Consumer<? super T> action);

说明: 接受一个函数式接口Consumer为入参并对所有元素执行该函数。

2、forEachOrdered()

void forEachOrdered(Consumer<? super T> action);

说明: 接受一个函数式接口Consumer<T>为入参并按元素顺序对所有元素执行该函数。

下面通过串行流和并行流说明两种遍历方式的区别:

Arrays.asList("1", "2", "3").stream().forEach(System.out::println);    // 1 2 3
Arrays.asList("1", "2", "3").stream().forEachOrdered(System.out::println);    // 1 2 3
Arrays.asList("1", "2", "3").parallelStream().forEach(System.out::println);    // 2 3 1
Arrays.asList("1", "2", "3").parallelStream().forEachOrdered(System.out::println);    // 1 2 3

(二)匹配

1、anyMatch()

boolean anyMatch(Predicate<? super T> predicate);

说明: 接受一个函数式接口Predicate<T>为入参,任何一个元素成功返回true。
示例:

System.out.println(Stream.of("1", "2", "3").anyMatch(x -> x.equals("2")));    // true

2、noneMatch()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值