java1.8 stream类的使用

1、为了简化集合操作

我们为集合对象创建stream对象,stream提供了很多方法,返回stream或者其他

2、stream的两种方法

中间方法:返回stream,类似过滤器似的,对集合元素做过滤

终端方法:返回其他,获取结果,结束流的执行用的,流不能再使用了

短路方法:使一个无限大的stream对象变为有限

3、执行过程

stream执行可以执行多个中间方法,然后最后执行一个终端方法,结束流的执行

执行过程可以看成一个一个依次循环执行的;

实际上stream实在最后一个方法执行时,再一次循环遍历里面做的所有中间方法

4、串行和并行

集合可以选择生成串行流或者并行流stream();parallelStream()

串行流执行过程中只有一个线程执行,并行会有多个线程分段执行集合元素

5、stream的api

中间方法:Intermediate 

map (mapToInt, flatMap 等)、 filter、 distinct、 sorted、 peek、 limit、 skip、 parallel、 sequential、 unordered

终端方法:Terminal 

forEach、 forEachOrdered、 toArray、 reduce、 collect、 min、 max、 count、 anyMatch、 allMatch、 noneMatch、 findFirst、 findAny、 iterator

短路方法:Short-circuiting 

anyMatch、 allMatch、 noneMatch、 findFirst、 findAny、 limit

6、常用方法

map/flatMap

把集合里面的元素替换成另外的元素

元素是集合时使用它

filter

filter 对原始 Stream 进行某项测试,通过测试的元素被留下来生成一个新 Stream。

forEach

forEach 方法接收一个 Lambda 表达式,然后在 Stream 的每一个元素上执行该表达式。

forEach 不能修改自己包含的本地变量值,也不能用 break/return 之类的关键字提前结束循环。

peek

和forEach类似,但是他是中间方法

findFirst

这是一个 termimal 兼 short-circuiting 操作,它总是返回 Stream 的第一个元素,或者空

等等。。。详情请查看jdk1.8api

7、示例

import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.Stream;
public class Test {
    public static void main(String[] args) {
        List<Integer> list = Arrays.asList(1,2,3,4);
        Stream<Integer> stream = list.stream();
        //list = list.stream().map((i) -> i+1).collect(Collectors.toList());
        //list = list.stream().filter((i) -> i > 1).collect(Collectors.toList());
        //stream.forEach(System.out::println);
        stream.peek((i) -> {i++;}).forEach(System.out::println);

    }
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值