我希望使用TreeSet
根据对象的属性删除重复的对象(这里是toString()
,它返回对象的名称),这是我的代码:
Set<Object> s = new TreeSet<>(new Comparator<Object>() {
@Override
public int compare(Object o1, Object o2) {
if (o1.toString().equals(o2.toString())) {
return 0;
} else {
return 1;
}
}
});
s.addAll(listComCopy);
listComCopy.clear();
listComCopy.addAll(s);
listComCopy
是对象列表。
它可以完成工作,但它只比较列表中的连续对象,因此如果我有 list(50).equals(list(150))
它将忽略。
您是否知道如何重构此代码以消除所有重复项,无论它们在列表中的顺序如何?
最佳答案
根据TreeSet的构造函数javadoc :
TreeSet(Comparator comparator)
Constructs a new, empty tree set, sorted according to the specified comparator.
您提供的比较器仅用于排序,不用于重复删除。
如果您想删除重复项,您应该在存储在此 TreeSet 上的对象类上实现 .equals()
和 .hashcode()
,以便删除重复项当您向其中添加新元素时,逻辑将开箱即用。
关于Java TreeSet 根据对象属性删除重复项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37813260/