使用stream API可高效实现集合去重与排序:1. 基本类型通过distinct()去重、sorted()排序,建议先去重后排序以提升性能;2. 自定义对象需结合Collectors.toMap()按指定字段去重(如name),再用Comparator.comparing()按需排序(如age);3. 若对象实现Comparable接口,可直接收集至TreeSet实现自动去重与排序。根据数据特性选择合适方案即可。

在Java中,使用Stream API可以非常方便地对集合数据进行去重和排序操作。核心方法是结合 distinct() 和 sorted() 中间操作来实现。
1. 去重并排序基本类型数据
对于如integer、String等基本类型的集合,可以直接调用 distinct() 去重,再通过 sorted() 排序:
List
List
.distinct()
.sorted()
.collect(Collectors.toList());
System.out.println(result); // 输出: [1, 2, 3, 4, 5]
注意:先去重再排序效率更高,避免对重复元素做不必要的排序。
2. 对对象集合去重并排序
如果处理的是自定义对象(如User),需要根据具体字段去重或排序。例如:
立即学习“Java免费学习笔记(深入)”;
class User {
private String name;
private int age;
// 构造函数、getter等省略
}
按某个字段去重(如name)时,distinct() 不够用,需借助 Collectors.toMap() 或使用Set辅助:
List
new User(“Alice”, 25),
new User(“Bob”, 30),
new User(“Alice”, 22)
);
List
.collect(Collectors.
toMap(User::getName, u -> u, (existing, replacement) -> existing))
.values()
.stream()
.sorted(Comparator.comparing(User::getAge))
.collect(Collectors.toList());
上面代码通过name作为key去重,保留第一个遇到的对象,然后按年龄排序。
3. 使用 TreeSet 实现自动排序去重
如果对象实现了 Comparable 接口,也可以直接收集到TreeSet中:
Set
.collect(Collectors.toCollection(TreeSet::new));
TreeSet本身保证元素唯一且有序,但注意它不保持插入顺序,而是自然排序或自定义比较器顺序。
基本上就这些常用方式。根据数据类型和需求选择合适的方法即可。


