Java中Stream.distinct()可去除集合重复元素,对基本类型自动去重,对对象需重写equals和hashCode方法以实现逻辑去重,如User类按name和age判断重复,distinct()保持插入顺序且适用于中小数据量,配合collect等终端操作使用。
Java 中的 Stream.distinct() 方法可以用来去除集合中重复的元素,返回一个没有重复元素的流。这个方法非常适用于对 List、Set 等集合进行去重操作,尤其在处理对象时,可以根据对象的实际属性来判断是否重复。
对于基本数据类型(如 Integer、String)的集合,distinct() 会根据值自动判断重复:
Listlist = Arrays.asList("apple", "banana", "apple", "orange", "banana"); List distinctList = list.stream() .distinct() .collect(Collectors.toList()); System.out.println(distinctList); // 输出: [apple, banana, orange]
如果要去重的对象是自定义类(如 User、Product),必须确保该类正确重写了 equals() 和 hashCode() 方法,否则 distinct() 会基于引用比较,无法识别逻辑上的重复。
例如:
class User {
private String name;
private int age;
public User(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
User user = (User) o;
return age == user.age && Objects.equals(name, user.name);
}
@Override
public int hashCode() {
return Objects.hash(name, age);
}
// getter 和 toString 可选
}
使用 Stream 去重:
Listusers = Arrays.asList( new User("Alice", 25), new User("Bob", 30), new User("Alice", 25) ); List distinctUsers = users.stream() .distinct() .collect(Collectors.toList()); System.out.println(distinctUsers.size()); // 输出: 2