Java Stream相关操作

Collectors.toList() 将流中的所有元素导出到一个列表( List )中,不会改变原来的数组,会将结果存入到新数组中

filter过滤:对数组中的每个元素都执行一次指定的函数(callback),并且创建一个新的数组,该数组元素是所有回调函数执行时返回值为 true(return true) 的原数组元素,返回值为false(return false)的原数组元素过滤掉。它只对数组中的非空元素执行指定的函数,没有赋值或者已经删除的元素将被忽略,同时,新创建的数组也不会包含这些元素。回调函数可以有三个参数:当前元素,当前元素的索引和当前的数组对象。

示例1:我们有一个整数流。首先我们将过滤,然后调试,然后映射,然后再次调试。

Stream.of(10, 11, 12, 13)
.filter(n -> n % 2 == 0)
.peek(e -> System.out.println("Debug filtered value: " + e))
.map(n -> n * 10)
.peek(e -> System.out.println("Debug mapped value: " + e))
.collect(Collectors.toList());

输出:

Debug filtered value: 10
Debug mapped value: 100
Debug filtered value: 12
Debug mapped value: 120

示例2:在这个例子中,我们有一个重复值的列表。我们将找到不同的值并使用peek方法进行调试。

List<String> list = Arrays.asList("AA", "BB", "CC", "BB", "CC", "AA", "AA");
String output = list.stream()
.distinct()
.peek(e -> System.out.println("Debug value: " + e))
.collect(Collectors.joining(","));
System.out.println(output);

输出

Debug value: AA
Debug value: BB
Debug value: CC
AA,BB,CC 

示例三:

List<String> debugList = new ArrayList<>();
List<String> names = Arrays.asList("Mahesh", "Suresh", "Mahendra");
names.stream()
.filter(el -> el.startsWith("M"))
.peek(e -> debugList.add(e))
.collect(Collectors.toList());
System.out.println(debugList);

输出

[Mahesh, Mahendra] 
list.stream().sorted//对集合进行排序
list.stream().sorted(Comparator.comparing(NepuWorkload::getWorkloadLevel).reversed()).collect(Collectors.toList())
//NepuWorkload::getWorkloadLevel按照NepuWorkload类的WorkloadLevel进行排序
//reversed()降序排序,不加默认升序排序



//先按年龄排序再按照身高排序(升序)多个字段排序

studentList.stream()
.sorted(Comparator.comparing(Student::getAge).thenComparing(Student::getHeight))
.forEach(student -> System.out.println(student.toString()));

 

 
 
 
 
posted @   自信且66  阅读(106)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话
点击右上角即可分享
微信分享提示