做者计划把Java Stream写成一个系列的文章,本文只是其中一节。更多内容期待您关注个人号!java
Java Stream函数式编程接口最初是在Java 8中引入的,而且与lambda一块儿成为Java开发的里程碑式的功能特性,它极大的方便了开放人员处理集合类数据的效率。从笔者以前看过的调查文章显示,绝大部分的开发者使用的JDK版本是java 8,其中Java Stream和lambda功不可没。linux
Java Stream就是一个数据流经的管道,而且在管道中对数据进行操做,而后流入下一个管道。有学过linux 管道的同窗应该会很容易就理解。在没有Java Stram以前,对于集合类的操做,更多的是经过for循环。你们从后文中就能看出Java Stream相对于for 循环更加简洁、易用、快捷。spring
管道的功能包括: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);
最终的输出结果是:[LEMUR, LION]。你们能够想想,上面的这些对数组进行遍历的代码,若是你用for循环来写,须要写多少行代码?来,咱们来继续学习Java Stream吧!springboot
使用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加载文本文件,而后逐行的对文件内容进行处理。code
Stream<string> lines = Files.lines(Paths.get("file.txt"));