美文网首页
JDK1.8流式编程

JDK1.8流式编程

作者: 我知他风雨兼程途径日暮不赏 | 来源:发表于2020-05-27 16:27 被阅读0次

1 生成流(Stream)

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

  • stream() − 为集合创建串行流。
  • parallelStream() − 为集合创建并行流。
// stream(): 将strings List进行流化
// filter(): 过滤处理,过滤规则为strings的元素不为空,即为空的从流中被剔除
// collect(): 重新进行collect收集转成List。
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
List<String> filtered = strings.stream().
  filter(string -> !string.isEmpty()).
  collect(Collectors.toList());

输出:

[abc, bc, efg, abcd, jkl]

Process finished with exit code 0

1.1 forEach方法

Stream 提供了新的方法 'forEach' 来迭代流中的每个数据。

//  forEach类似JAVA之前的for(String $ : strings)。
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
        strings.stream().forEach($ -> System.out.println($));

输出:

abc

bc
efg
abcd

jkl

Process finished with exit code 0

1.2 map方法

map 方法用于映射每个元素到对应的结果。

 List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
        /***
         * map():相当于元素别名 -> 元素新值,value必须是和List中一致的泛型
         */
        strings.stream()
                .map($ -> $+$)
                .forEach($-> System.out.println($));

输出:

abcabc

bcbc
efgefg
abcdabcd

jkljkl

Process finished with exit code 0

1.3 filter方法

filter 方法用于通过设置的条件过滤出元素。

// stream(): 将strings List进行流化
// filter(): 过滤处理,过滤规则为strings的元素不为空,即为空的从流中被剔除
// collect(): 重新进行collect收集转成List。
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
List<String> filtered = strings.stream().
  filter(string -> !string.isEmpty()).
  collect(Collectors.toList());

输出:

[abc, bc, efg, abcd, jkl]

Process finished with exit code 0

1.4 limit方法

limit 方法用于获取指定数量的流。

 List<String> strings = Arrays.asList("abc", "bc", "efg", "abcd","", "jkl");
        /***
         * limit(number):相当于for(int i=0;i<number;i++)
         */
        strings.stream()
                .map($ -> $+$)
                .limit(2)
                .forEach($-> System.out.println($));

输出:

abcabc
bcbc

Process finished with exit code 0

1.5 sorted方法

sorted 方法用于对流进行排序。

List<String> strings = Arrays.asList("abc", "bc", "efg", "abcd","", "jkl");
        /***
         * sorted():正序排序
         * sorted(Comparator.reverseOrder()):倒序排序,也可在sorted()里自定义排序方法
         */
        strings.stream().sorted()
                .forEach($-> System.out.println($));
        System.out.println("-----------分割线----------");
        strings.stream().sorted(Comparator.reverseOrder())
                .forEach($-> System.out.println($));

输出:

abc
abcd
bc
efg
jkl
-----------分割线----------
jkl
efg
bc
abcd
abc


Process finished with exit code 0

1.6 Collectors 聚合

Collectors 类实现了很多归约操作,例如将流转换成集合和聚合元素。

 List<String> strings = Arrays.asList("abc", "bc", "efg", "abcd","", "jkl");
 System.out.println(strings.stream()
             .filter(s -> !s.equals(""))
             .collect(toList()));
 System.out.println(strings.stream()
             .collect(joining(",")));

输出:

[abc, bc, efg, abcd, jkl]
abc,bc,efg,abcd,,jkl

Process finished with exit code 0

1.7 统计函数

另外,一些产生统计结果的收集器也非常有用。它们主要用于int、double、long等基本类型上,它们可以用来产生类似如下的统计结果。

List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);
IntSummaryStatistics stats = numbers.stream().mapToInt(x->x).summaryStatistics();
System.out.println("列表中最大的数 : " + stats.getMax());
System.out.println("列表中最小的数 : " + stats.getMin());
System.out.println("所有数之和 : " + stats.getSum());
System.out.println("平均数 : " + stats.getAverage());

输出:

列表中最大的数 : 7
列表中最小的数 : 2
所有数之和 : 25
平均数 : 3.5714285714285716

Process finished with exit code 0

1.8 reduce方法

reduce:(T identity,BinaryOperator)/reduce(BinaryOperator)-可以先设置初始值,并将流中元素反复结合起来,得到一个值。

 List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);
System.out.println(numbers.stream().limit(3).reduce(0,(x,y)->x+y));

输出:

7

Process finished with exit code 0

2 灵活的运用

2.1 简单的List转Map

List<Integer> nums = Lists.newArrayList(1,2,3,1,10,2,3,10,10);

Map<Integer,Integer> map2 =  nums.stream().distinct().map(num -> {
    return new ImmutablePair<Integer,Integer>(num,1);
}).collect(Collectors.toMap(pair -> pair.left,pair -> pair.right));
System.out.println(map2);

================================
{1=1, 2=1, 3=1, 10=1}

2.2 统计元素出现的次数

List<Integer> nums = Lists.newArrayList(1,2,3,1,10,2,3,10,10);

// 统计nums每个元素出现的次数
Map<Integer,Integer> map = Maps.newHashMap();
nums.stream().forEach(pair->{
    map.compute(
             pair,(key, val) -> val = (val==null ? 1 : val+1)
    );
});
System.out.println(map);
------------------------------------------------
{1=2, 2=2, 3=2, 10=3}

Process finished with exit code 0

2.3 将map转成同等val数量的key元素list

// 将map中的key val转成同等val数量的key
Map<Integer,Integer> map1 = Maps.newHashMap();
map1.put(10,2);
map1.put(3,1);
map1.put(7,2);

List list = map1.entrySet().stream().map(entry -> {
    return IntStream.range(0, entry.getValue()).mapToObj($ -> entry.getKey()).collect(Collectors.toList());
}).flatMap(Collection::stream).collect(toList());
========================================
[3, 7, 7, 10, 10]

相关文章

  • JDK1.8流式编程

    1 生成流(Stream) 在 Java 8 中, 集合接口有两个方法来生成流: stream() − 为集合创建...

  • 流式编程

    日常使用 前言:依旧使用购物车的数据 生成流的方式 收集器 收集器:将流的元素累计成一个结果比如:将筛选过的数据,...

  • 流式编程

    创建流8种方法 1.创建空流 这个方法经常被用在创建一个不含元素的空的流进行返回,避免返回null 2.从集合中创...

  • Java核心教程5: 流式编程

    本次课程的标题不像之前那样易懂,是一个陌生的概念,“流式编程”是个什么东西? 在了解流式编程之前先思考一下“流”,...

  • 流式数据处理

    流式数据处理的应用场景,包括基本概念和处理方式;也介绍了流式处理系统常见的编程模型和框架,最后介绍了流式数据处理的...

  • 十二、从Camel中学习Flunt Api设计

    以下为我目前对流式编程的理解。 一、 流式的好处 更接近与自然语言; 操作连贯,一行搞定(如Builder); 二...

  • JDK1.8新特性之CompletableFuture

    CompletableFuture前言 CompletableFuture是JDK1.8提供的异步函数式编程方式的...

  • io流&流式编程

    跟C++的流有什么区别? 百度搜索(C++ java 流 stream)(理解java中的流) C++流的原理:可...

  • Spark流式编程介绍 - 编程模型

    来源Spark官方文档http://spark.apache.org/docs/latest/structured...

  • jdk8的Stream学习之创建流

    JDK8的流式编程来来回回走马观花也看了几遍了。工作中一般的集合类操作能用流式操作的也都用流式操作。今天正儿八经的...

网友评论

      本文标题:JDK1.8流式编程

      本文链接:https://www.haomeiwen.com/subject/lvywahtx.html