java set存自定义类时怎么判别重复元素
时间: 2024-09-22 18:07:10 浏览: 43
在Java中,Set集合(如HashSet、TreeSet等)不允许存储重复元素,这是它们的一个基本特性。如果你想在Set中存储自定义类的对象,并避免重复,你需要确保自定义类实现了equals()和hashCode()方法。
1. equals(): 当两个对象相等时,它们的equals()方法应该返回true。如果两个实例在所有属性上都相同,则它们应该是相等的。
2. hashCode(): 这个方法用于快速判断对象是否与其他已知对象“冲突”,即散列到相同的索引位置。hashCode()和equals()需要保持一致性,也就是说,如果两个对象认为彼此相等(equals()返回true),那么他们的hashCode()也应该返回相同的值。
如果你已经实现了这两个方法,自定义类的对象会自动处理去重。例如:
```java
class CustomClass {
private String field1;
// ...其他字段
@Override
public boolean equals(Object obj) {
if (this == obj) return true;
if (obj == null || getClass() != obj.getClass()) return false;
CustomClass other = (CustomClass) obj;
return field1.equals(other.field1);
}
@Override
public int hashCode() {
return Objects.hash(field1);
}
}
// 使用HashSet存储
Set<CustomClass> customSet = new HashSet<>();
customSet.add(new CustomClass(...));
```
因为HashSet基于哈希表实现,它会利用hashCode()进行快速查找,所以如果有重复的CustomClass对象,添加时会自动忽略重复。
阅读全文