当前位置: 首页 > article >正文

Stream API 如何使用

简介

Stream 就像工厂中的流水线,适合重复、简单的操作,当数据量较大时,使用 Stream 会获得效率上的提升

如何构建流

  1. Stream.of()
  2. Arrays.stream()
  3. Collection.stream()

流有那些种类

  1. 并行流
  2. 串行流

流 API 的种类

流 API 可以分为两大类:中间 API 和终结 API

并行流的原理

利用 ForkoinPool ,为每一个 CPU 分配一个任务,最后将任务汇总、收集

案例一,过滤满足条件的元素

public class StreamTest {
    public static void main(String[] args) {
        // 1 ~ 10 的整数列表
        List<Integer> numbers = List.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

        List<Integer> evenNumbers = numbers.stream()
                // 留下 n % 2 == 0 为真的元素
                .filter(n -> n % 2 == 0)
                // 留下大于 3 的偶数
                .filter(n -> n > 3)
                // 转换为 List
                .toList();
        // 输出
        System.out.println(evenNumbers);
    }
}

案例二,将多维数组转为一维数组

public class StreamTest {
    public static void main(String[] args) {
        // 二维字符串列表
        List<List<String>> array = List.of(
                List.of("A", "B", "C"),
                List.of("D", "E", "F"),
                List.of("G", "H", "I")
        );

        List<String> list = array.stream()
                // flatMap 进行展开
                .flatMap(List::stream)
                .toList();

        System.out.println(list);
    }
}

案例三,查找满足条件的第一个元素

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> integers = List.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

        // findFirst 方法返回 Optional 对象,为了防止流为空的情况
        Optional<Integer> first = integers.stream()
                .filter(integer -> (integer & 1) == 0)
        // 串行流 findFirst 和 findAny 行为一致 
                .findFirst();

        System.out.println(first.orElse(0));
    }
}

案例四,判断流中的元素是否存在满足某一条件的元素

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> integers = List.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

        System.out.println(integers.stream()
                // allatch 用于判断流中元素是否都满足某一特定条件
                .anyMatch(integer -> integer % 2 == 0));
    }
}

案例五,对流中的元素进行类型转换

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> integers = List.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

        integers.stream()
                .map(String::valueOf)
                .toList()
                .forEach(s -> System.out.println(s instanceof String));
    }
}

案例六,计算列表中的数字和

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> integers = List.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

        int sum = integers.stream()
                .mapToInt(Integer::intValue)
                .sum();
        
        System.out.println(sum);
    }
}

案例七,对列表中的元素进行累加

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> integers = List.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

        // 基本类型的 Stream 拥有求和、累加、最大、最小的直接 API
        Optional<Integer> sum = integers.stream()
                .reduce(Integer::sum);
        
        sum.ifPresent(System.out::println);
    }
}

案例八,并行流的累乘

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> integers = List.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

        Integer reduce = integers.stream()
                .parallel()
                .reduce(1,
                        (a, b) -> a * b,  // 累乘器
                        (a, b) -> a * b); // 结合器

        System.out.println(reduce);
    }
}

参考

The Stream API - Dev.java

Using Optionals - Dev.java

Writing Your First Lambda Expression - Dev.java

java.util.stream (Java SE 17 & JDK 17)


http://www.kler.cn/a/301831.html

相关文章:

  • 功能篇:mybatis中实现缓存
  • 【LeetCode Hot100 贪心算法】 买卖股票的最佳时机、跳跃游戏、划分字母区间
  • MySQL insert or update方式性能比较
  • C语言冒泡排序教程简介
  • Apache Traffic存在SQL注入漏洞(CVE-2024-45387)
  • 每日一题-两个链表的第一个公共结点
  • Vue3 el-switch @change事件在初始化时会自动调用问题
  • docker_快速部署flask架构下的web容器
  • redis群集的三种模式
  • MK 米客方德 TF 卡 —— 录音笔、领夹麦、电池门铃等设备的高效能、低功耗存储首选
  • 双线性插值算法
  • 19:I2C一:程序模拟I2C通信时序
  • [数据集][目标检测]汽车头部尾部检测数据集VOC+YOLO格式5319张3类别
  • 配环境时的一些记录
  • 好看好听的小猪包扩音器,轻巧便携更好用,得胜E10上手
  • C++库之一:Loki
  • Python在音频传输中的应用实例解析
  • C# HttpClient 实现HTTP Client 请求
  • 智能体 vs AI智能体:区别与联系,一文读懂!
  • 【React+Ts+Vite+AntDesign】从0到1基础项目搭建(动态路由)
  • 【Python报错已解决】AttributeError: ‘str‘ object has no attribute ‘read‘
  • python学习之字符串操作
  • Spring统一功能+SpringAOP
  • 黑马头条第八天实战(上)
  • 【oj刷题】滑动窗口篇:滑动窗口的应用场景和注意事项
  • RTMP和WebRTC使用场景有哪些差别?