四、Stream使用详解
好了,背景知识介绍完成,并且我们在最开始也对Stream有了一个大致的了解,在本章中我们详细的介绍一下Stream,每一个示例都会有相应的代码配合,让读者理解更加的透彻。
对 Stream 的使用就是实现一个 filter-map-reduce 过程,产生一个最终结果,或者导致一个副作用(side effect),当我们使用流的时候,通常会包括三个基本的步骤:
v 获取数据
v 转换数据,每次的转换不会改变原有Stream而是会返回一个新的Stream,并且转换可以有多次的转换。
v 执行操作获取想要的结果
4.1 如何获得Stream
获取流的方式有很多种,我们在这本节中,逐个的介绍,我将代码都放在junit测试代码中。
4.1.1 From Collections
@Test public void fromCollections() { List<String> list = Collections.emptyList(); Stream<String> stream = list.stream(); Stream<String> parallelStream = list.parallelStream(); } |
4.1.2 From Arrays
@Test public void fromArrays() { int[] array = {1,2,3,4,5}; IntStream stream = Arrays.stream(array); Stream<Integer> integerStream = Stream.of(1, 2, 3, 4, 5, 6); } |
4.1.3 From Static Factory
@Test public void fromArrays() { int[] array = {1,2,3,4,5}; IntStream stream = Arrays.stream(array); Stream<Integer> integerStream = Stream.of(1, 2, 3, 4, 5, 6); } |
4.1.4 From Files
@Test public void fromFiles() { Path path = Paths.get(""); try { Stream<Path> stream = Files.walk(path); } catch (IOException e) { e.printStackTrace(); } } |
4.1.5 Build By Yourself
除了一些常见的方式获取Stream之外,我们还可以自己构造如何获取一个Stream,这种情形通常用于随机数、常量的 Stream,或者需要前后元素间维持着某种状态信息的 Stream。把 Supplier 实例传递给 Stream.generate() 生成的 Stream,默认是串行(相对 parallel 而言)但无序的(相对 ordered 而言)。由于它是无限的,在管道中,必须利用 limit 之类的操作限制 Stream 大小。
@Test public void generateByYourself() { Random random = new Random(System.currentTimeMillis()); Supplier<Integer> supplierRandom |