Collectors.toList() 将流中的所有元素导出到一个列表( List )中,不会改变原来的数组,会将结果存入到新数组中
示例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()));
原创文章,作者:1402239773,如若转载,请注明出处:https://blog.ytso.com/272794.html