Java 8 Stream API说明

Java 8增长了不少强大的功能,流(stream)就是其中之一。如今对api的使用作个说明:api

map数组

对流中的元素作转换,目前jdk提供了mapToInt,mapToLong,mapToDouble转换为对应的流。spa

 Stream.of("a","b").map(String::toUpperCase).forEach(System.out::println);

>>>>>
A
B
Stream.of("1","2").mapToDouble(Double::valueOf).forEach(System.out::println);
>>>>>>

1.0
2.0code

forEach、 forEachOrdered:迭代流的元素并执行action。 二者的区别在:后者在并行的状况下能保证action执行的顺序。blog

parallel:并行计算,底层采用的folk/join排序

 Stream.of(1,3,2).parallel().forEachOrdered(System.out::println);
>>>>
1
3
2

 Stream.of(1,3,2).parallel().forEach(System.out::println);
>>>>
3
1
2

distinct:去重ip

sorted:排序it

Stream.of(1,3,3,2).distinct().sorted().forEach(System.out::println);
>>>
1
2
3

peek:对流执行一个actionio

Stream.of(1,3,3,2).filter(i -> i > 2).peek(System.out::println).collect(Collectors.toList());
>>>
3
3

limit:限制流元素的个数class

skip:跳过几个元素

 Stream.of(1,3,3,2).skip(2).peek(System.out::println).collect(Collectors.toList());
>>>
3
2
Stream.of(1,3,3,2).limit(2).peek(System.out::println).collect(Collectors.toList());
>>>
1
3

sequential: 串行流,没看出区别

Stream.of(1,3,3,2).sequential().forEach(System.out::println);
toArray():将流转换成数组
相关文章
相关标签/搜索