zoukankan      html  css  js  c++  java
  • 恕我直言你可能真的不会java第2篇:Java Stream API?

    file

    一、什么是Java Stream API?

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

    file

    二、Stream API代替for循环

    我们先来看一个例子:

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

    欢迎关注我的博客,里面有很多精品合集

    • 本文转载注明出处(必须带连接,不能只转文字):字母哥博客

    觉得对您有帮助的话,帮我点赞、分享!您的支持是我不竭的创作动力! 。另外,笔者最近一段时间输出了如下的精品内容,期待您的关注。

  • 相关阅读:
    vue富文本编辑器
    vue图片上传组件
    vue全局使用axios插件请求ajax
    vue项目初始化时npm run dev报错webpack-dev-server解决方法
    vue axios使用form-data的形式提交数据
    react-keep-alive
    create-react-app 兼容 ie9
    next-定义路由
    next-支持css样式和按需加载antd
    react-错误边界
  • 原文地址:https://www.cnblogs.com/zimug/p/13152351.html
Copyright © 2011-2022 走看看