Stream JDK1.8特性
程序员文章站
2022-06-04 19:29:24
...
(1)stream 流
Stream(流)是一个来自数据源的元素队列并支持聚合操作
元素是特定类型的对象,形成一个队列。 Java中的Stream并不会存储元素,而是按需计算。
数据源 流的来源。 可以是集合,数组,I/O channel, 产生器generator 等。
聚合操作 类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。
和以前的Collection操作不同, Stream操作还有两个基础的特征:
Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风格(fluent style)。 这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( short-circuiting)。
内部迭代: 以前对集合遍历都是通过Iterator或者For-Each的方式, 显式的在集合外部进行迭代, 这叫做外部迭代。 Stream提供了内部迭代的方式, 通过访问者模式(Visitor)实现。
https://www.ibm.com/developerworks/cn/java/j-lo-java8streamapi/
(2)运用
// 根据特定条件过滤结合
List<GradeInfo> filter = lists.stream().filter(gradeInfo01 -> gradeInfo01.getFlagGender().equals("男"))
.collect(Collectors.toList());
// 降序排列 thenComparing() 即为下一个排序条件
List<GradeInfo> collect = lists.stream().sorted(Comparator.comparing(GradeInfo::getAge).reversed())
.collect(Collectors.toList());
// 返回某个属性
List<Integer> coList = lists.stream().map(GradeInfo::getAge).collect(Collectors.toList());
// 转化为map
final Map<String, GradeInfo> gradeInfoMap = lists.stream()
.collect(Collectors.toMap(GradeInfo::getUserId, Function.identity()));
// 分组转map
final Map<Integer, List<GradeInfo>> gradeInfoMap01 = lists.stream()
.collect(Collectors.groupingBy(GradeInfo::getAge));
// 获取年龄最大值
Integer integer = lists.stream().map(GradeInfo::getAge).max(Integer::compare).get();