欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-01-05 18:02:59
导读 作者计划把Java Stream写成一个系列的文章,本文只是其中一节。更多内容期待您关注我的号! 一、什么是Java Stream? Java Stream函数式编程接口最初是在Java 8中引入的,并且与lambda一起成为Java开发的里程碑式的功能特性,它极大的方便了开放人员处理集合类数 ......

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

导读

作者计划把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管道处理之后,转化为另一组集合或数据输出。

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吧!

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"));

期待您的关注

上一篇:

下一篇: