• 8个实用的Java Streams API


    分享8个开箱即用的API,方便日常处理集合。

    1. 快速过滤空值:Stream.ofNullable

    该方法是在 Java 9 中引入的,有助于过滤集合中的所有空值,从而可能使我们避免空指针异常。

    在下面的示例中,有一个包含 null 的List。此时,我们可以使用Stream.ofNullable方法对其进行过滤。

    List names = Arrays.asList("Alice", null, "Bob", null, "Charlie");
    List nonNuLLNames = names.stream()
        .flatMap(Stream::ofNullable)
        .collect(Collectors.toList());
    System.out.println(nonNuLLNames);
    

    执行上述代码,将输出:

    [Alice, Bob, Charlie]
    

    2. 流式迭代:Stream.iterate()

    Stream.iterate()方法用于创建无限的序列流。它采用种子和一元函数,将函数应用于前一个元素。

    在下面的例子中,我们的种子是0,一元运算函数是 n -> n+2。

    Stream.iterate(seed: 0, n -> n+2)
        .Limit( maxsize: 10)
        .forEach(e-> {
            System,out printin(e)
        });
    

    执行上述代码,将输出:

    0
    2
    4
    6
    8
    10
    12
    14
    16
    18
    

    注意:由于Stream.iterate()生成的是无限序列流。因此我们应该定义终止条件,例如:limit、findFirst 或 findAny 等,以避免无限循环。

    3. 集合转换:collectingAndThen()

    collectingAndThen()方法是在 Java 8 中引入的。它是一种特殊的收集器,允许您对另一个收集器的结果执行特殊类型的转换。

    在下面的示例中,我们的收集器通过首先使用索引到大写操作进行映射,然后使该映射成为不可修改的Map进行转换。

    List fruits = Arrays.asList("apple", "banana","orange");
    Map result = fruits.stream()
      .collect(Collectors.collectingAndThen(
        Collectors.toMap(fruits::index0f,String::toUpperCase),
        Collections::unmodifiableMap
      ));
    System.out.println(result)
    

    执行上述代码,将输出:

    {0=APPLE, 1=BANANA, 2=ORANGE}
    

    4. 删除和截取:dropWhile()takeWhile()

    dropWhile()takeWhile()方法是在 java9 中引入的,用于连续处理流。

    • takeWhile():返回符合条件的元素流
    • dropWhile():从元素流中删除符合条件的元素

    在下面的示例中,我们删除小于3的元素,然后返回元素小于6的元素流。

    List numbers = List.of(1,2,3,4,5,6,7);
    numbers.stream()
      .dropWhile(n -> n < 3)
      .takeWhile(n -> n < 6)
      .forEach(System.out::println);
    

    执行上述代码,将输出:

    3
    4
    5
    

    5. 整数流:IntStream

    IntStream 在 Java 8 中引入,用于快速生成整数流,常用有的以下两个方法:

    • IntStream.range() 方法生成一个整数流,该整数流不包含结尾数字
    • IntStream.rangeClosed() 方法生成一个整数流,该整数流包含结尾数字

    下面的例子,可以清晰的看到区别:

    // Prints 1,2,3,4
    IntStream.range(1,5).forEach(System.out::println); 
    // Prints 1,2,3,4,5
    IntStream.rangeClosed(1,5).forEach(System.out::println); 
    

    6. 应用多个收集器:teeing()

    Java 12 中引入的teeing()方法是为了我们可以在元素流上一起应用两个单独的收集器而创建的。

    在下面的示例中,我们使用teeing()计算元素流的最大值和最小值,然后将结果以Map形式返回。

    Stream nums = Stream.of( ...values: 1 2,3 4);
    Map collect = nums.collect(Collectors.teeing(
      ColLectors.maxBy(Integer::compareTo),
      CoLlectors.minBy(Integer::compareTo),
      (e1, e2) -> Map.of( k1: "min", e1.get(), k2: "max", e2.get())
    ));
    
    System.out.println(collect);
    

    执行上述代码,将输出:

    {max=1, min=4}
    

    7. 合并流:Stream.concat()

    Stream.concat()方法可以用来连接两个流并生成一个新流。

    Stream stream1 = Stream.of(...values: 1,2,3);
    Stream stream2 = Stream.of(...values: 4,5,6);
    Stream.concat(stream1, stream2)
      .forEach(System.out::println);
    

    执行上述代码,将输出:

    1
    2
    3
    4
    5
    6
    

    8. 分组:Collectors.partitioningBy

    Collectors.partitioningBy可以用来对流进行分组。

    在下面的示例中,我们根据元素的字符串长度分为两个不同的组。

    Map> result1 = Stream.of(...values: "apple", "banana", "orange", "grape")
      .collect(Collectors.partitioningBy(f -> f.length() > 5));
    
    System.out.println(result1);
    

    执行上述代码,将输出:

    {false=[apple, grape], true=[banana, orange]}
    

    今天的分享就到这里。如果您学习过程中如遇困难?可以加入我们超高质量的技术交流群,参与交流与讨论,更好的学习与进步

    欢迎关注我的公众号:程序猿DD。第一时间了解前沿行业消息、分享深度技术干货、获取优质学习资源

  • 相关阅读:
    工业蒸汽量预测(速通一)
    35.搜索插入位置
    基于ssm的机场网上订票系统设计与实现-计算机毕业设计源码+LW文档
    原以为哈夫曼树、哈夫曼编码很难,结果……
    初识设计模式 - 职责链模式
    【计算机视觉40例】案例39:易容术(换脸术、合成人脸)
    鸿鹄电子招投标系统:基于Spring Boot、Mybatis、Redis和Layui的企业电子招采平台源码与立项流程
    在 rider 里用配置 Perforce(P4)的注意事项
    React源码分析(一)Fiber
    【字节跳动实习面经(测试开发岗 二面)希望渺茫】
  • 原文地址:https://www.cnblogs.com/didispace/p/18231426