1 引言
在我们的日常编程任务中,对于集合的制造和处理是必不可少的。当我们需要对于集合进行分组或查找的操作时,需要用迭代器对于集合进行操作,而当我们需要处理的数据量很大的时候,为了提高性能,就需要使用到并行处理,这样的处理方式是很复杂的。流可以帮助开发者节约宝贵的时间,让以上的事情变得轻松。
2 流简介
流到底是什么呢?简要的定义为“从支持数据处理操作的源生成的元素序列”,接下来对于这个定义进行简要分析。
2.1 支持数据处理操作
流的数据处理操作和数据库的可以声明式的指定分组或查找等功能支持类似,和函数式编程的思想一致,如filter、map、reduce、find、match、sort等操作,这些流操作可以串行执行,也可以并行执行。
2.2 源
流会使用一个提供数据的源,可以通过三种方式来创建对象流,一种是由集合对象创建流:
List<Integer> list = Arrays.asList(111,222,333);
Stream<Integer> stream = list.stream();
一种是由数组创建流:
IntStream stream = Arrays.stream(new int(){111,222,333});
一种是由静态方法Stream.of()创建流,底层还是Arrays.stream():
Stream<Integer> stream = Stream.of(111, 222, 333);
Stream stream = Stream.of(111, 222, 333);
从有序集合生成流时会保留原有的顺序。由列表生成的流,其元素顺序与列表一致。
还有两种特殊的流:
- 空流

本文介绍了Java中的流(Stream)概念,它是处理集合数据的一种高效方式。流提供了函数式编程风格的filter、map、reduce等操作,支持串行和并行处理,可以用于简化复杂的集合操作。通过示例展示了如何从集合创建流,以及如何通过中间操作和终端操作处理数据,最后强调了流的不可变性和一次性使用特性。
最低0.47元/天 解锁文章
2256

被折叠的 条评论
为什么被折叠?



