答案是使用Stream的toMap根据属性去重最推荐,通过name为key保留首个对象;也可重写equals/hashCode用LinkedHashSet去重以保持顺序;或手动遍历用Set记录已出现属性值。

在Java中,如果想根据对象的某个属性值对自定义对象集合进行去重,可以使用多种方式实现。核心思路是利用该属性作为判断依据,确保其唯一性。以下是几种常用且有效的方法。
1. 使用Stream和Collectors.toMap
这是最常用的方式之一,通过将对象按指定属性作为key存入Map,自动覆盖重复key的值,从而实现去重。
假设有一个Person类:
class Person {private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
// getter方法
public String getName() { return name; }
public int getAge() { return age; }
}
现在要根据name属性去重:
立即学习“Java免费学习笔记(深入)”;
Listnew Person("Alice", 25),
new Person("Bob", 30),
new Person("Alice", 28)
);
List
.collect(Collectors.toMap(
Person::getName, // 以name为key
p -> p, // value为对象本身
(existing, replacement) -> existing // 遇到重复时保留第一个
))
.values()
.stream()
.toList();
这样结果中只保留第一个名为"Alice"的对象。
2. 使用LinkedHashSet保持插入顺序
如果你希望去重的同时保持原始顺序,可以借助LinkedHashSet,前提是你的类重写了equals和hashCode方法,仅基于目标属性。
修改Person类:
@Overridepublic boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Person person = (Person) o;
return Objects.equals(name, person.name);
}
@Override
public int hashCode() {
return Objects.hash(name);
}
然后使用Set去重:
SetList
这种方式简洁,但会改变类的整体行为(所有比较都基于name),需谨慎使用。
3. 自定义逻辑遍历去重
如果不想修改类或使用复杂结构,可以用一个临时集合记录已出现的属性值,手动过滤。
SetList
for (Person p : persons) {
if (seen.add(p.getName())) { // add返回true表示之前不存在
result.add(p);
}
}
这种方法灵活、易理解,适合在性能要求不高或逻辑较复杂的场景下使用。
基本上就这些。推荐优先使用Stream + toMap的方式,代码简洁且功能明确。如果需要频繁比较对象,再考虑重写equals/hashCode。关键是根据实际需求选择合适的方法。不复杂但容易忽略细节。









