Java-Stream函数式编程案例图文详解

37次阅读

共计 1600 个字符,预计需要花费 4 分钟才能阅读完成。

导读

作者计划把 Java Stream 写成一个系列的文章,本文只是其中一节。更多内容期待您关注我的号!

一、什么是 Java Stream?

Java Stream 函数式编程接口最初是在 Java 8 中引入的,并且与 lambda 一起成为 Java 开发的里程碑式的功能特性,它极大的方便了开放人员处理集合类数据的效率。从笔者之前看过的调查文章显示,绝大部分的开发者使用的 JDK 版本是 java 8,其中 Java Stream 和 lambda 功不可没。

Java Stream 就是一个数据流经的管道,并且在管道中对数据进行操作,然后流入下一个管道。有学过 linux 管道的同学应该会很容易就理解。在没有 Java Stram 之前,对于集合类的操作,更多的是通过 for 循环。大家从后文中就能看出 Java Stream 相对于 for 循环更加简洁、易用、快捷。

管道的功能包括:Filter(过滤)、Map(映射)、sort(排序)等,集合数据通过 Java Stream 管道处理之后,转化为另一组集合或数据输出。

我们先来看一个例子:

List<String> nameStrs = Arrays.asList("Monkey", "Lion", "Giraffe","Lemur");

List<String> list = nameStrs.stream()
        .filter(s -> s.startsWith("L"))
        .map(String::toUpperCase)
        .sorted()
        .collect(toList());
System.out.println(list);
  • 首先,我们使用 Stream() 函数,将一个 List 转换为管道流
  • 调用 filter 函数过滤数组元素,过滤方法使用 lambda 表达式,以 L 开头的元素返回 true 被保留,其他的 List 元素被过滤掉
  • 然后调用 Map 函数对管道流中每个元素进行处理,字母全部转换为大写
  • 然后调用 sort 函数,对管道流中数据进行排序
  • 最后调用 collect 函数 toList,将管道流转换为 List 返回

最终的输出结果是:[LEMUR, LION]。大家可以想一想,上面的这些对数组进行遍历的代码,如果你用 for 循环来写,需要写多少行代码?来,我们来继续学习 Java Stream 吧!

二、将数组转换为管道流

使用 Stream.of() 方法,将数组转换为管道流。

String[] array = {"Monkey", "Lion", "Giraffe", "Lemur"};
Stream<String> nameStrs2 = Stream.of(array);

Stream<String> nameStrs3 = Stream.of("Monkey", "Lion", "Giraffe", "Lemur");

三、将集合类对象转换为管道流

通过调用集合类的 stream() 方法,将集合类对象转换为管道流。

List<String> list = Arrays.asList("Monkey", "Lion", "Giraffe", "Lemur");
Stream<String> streamFromList = list.stream();

Set<String> set = new HashSet<>(list);
Stream<String> streamFromSet = set.stream();

四、将文本文件转换为管道流

通过 Files.lines 方法将文本文件转换为管道流,下图中的 Paths.get() 方法作用就是获取文件,是 Java NIO 的 API!

也就是说:我们可以很方便的使用 Java Stream 加载文本文件,然后逐行的对文件内容进行处理。

Stream<String> lines = Files.lines(Paths.get("file.txt"));

期待您的关注

  • 博主最近新写了一本书:《手摸手教您学习 SpringBoot 系列 -16 章 97 节》
  • 本文转载注明出处(必须带连接,不能只转文字):字母哥博客。

正文完
 0