一、stream简介
java.util.stream这个包引入了流。
流和集合有以下几个不同的地方。
- 没有存储。流不是存储元素的数据结构,相反,它通过计算操作传递来自诸如数据结构,数组,构造器函数或者I/O通道等源的元素。
- 本质上讲,流的操作会产生结果,但不会修改其来源。例如Stream从集合获取一个没有过滤元素的新元素,而不是从集合中删除过滤元素。
- 惰性求值,流的许多操作都是惰性的。
- 及早求值,在一系列惰性求值之后调用一个及早求值的方法,来生成最终的结果。
- 集合有大小限制,但是流没有大小限制。
- 流元素在声明周期中只被访问一次,就像迭代器一样,当需要再次访问相同的元素时必须生成新的流。
二、stream流的创建与使用
1、生成流
- Collection.stream() 使用集合创建流;
- Collection.parallelStream() 使用集合创建并行流;
- Arrays.stream(Object[]);
- Stream.of(Object[]), IntStream.range(int, int) 或Stream.iterate(Object, UnaryOperator), Stream.empty(),
- Stream.generate(Supplier f);
- BufferedReader.lines();
- Random.ints();
- BitSet.stream(),
- Pattern.splitAsStream(java.lang.CharSequence),和JarFile.stream()。
2、流的中间操作(无副作用)
- filter(Predicate)与预期匹配的流的元素
- map(Function<T, U>)将 input Stream 的每一个元素,映射成 output Stream 的另外一个元素。
- flatMap(Function<T, Stream> 将提供的流处理函数应用于流元素后获得的流元素
- distinct()已删除了重复的流元素
- sorted() 按自然顺序排序的流元素
- Sorted(Comparator) 按提供的比较符排序的流元素
- limit(long)截断至所提供长度的流元素
- skip(long)丢弃了前 N 个元素的流元素
- takeWhile(Predicate)(仅限 Java 9)在第一个提供的预期不是 true 的元素处阶段的流元素
- dropWhile(Predicate)(仅限 Java 9)丢弃了所提供的预期为 true 的初始元素分段的流元素
3、终止操作
- forEach(Consumer action) 将提供的操作应用于流的每个元素。
- toArray() 使用流的元素创建一个数组。
- reduce(…) 将流的元素聚合为一个汇总值。
- collect(…) 将流的元素聚合到一个汇总结果容器中。如字符串拼接、数值的 sum、min、max、average 都是特殊的 reduce。
- min(Comparator) 通过比较符返回流的最小元素。
- max(Comparator) 通过比较符返回流的最大元素。
- count() 返回流的大小。
- {any,all,none}Match(Predicate) 返回流的任何/所有元素是否与提供的预期相匹配。
- findFirst() 返回流的第一个元素(如果有)
- findAny()
1774

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



