重写hashcode和equals方法代码
时间: 2024-10-16 18:04:39 浏览: 34
在Java中,当你创建自定义对象并希望它们能够参与哈希表(如HashMap、HashSet)或其他基于哈希的数据结构时,你需要覆盖`hashCode()`和`equals()`方法。这两个方法在确定对象在哈希表中的位置和是否认为两个对象相等方面至关重要。
`hashCode()`方法的主要职责是返回一个整数,这个值代表对象的“哈希码”,它的目的是为了快速查找。理想情况下,不同的对象应该有不同的哈希码,而且相同的对象每次调用都应该返回相同的哈希码。例如:
```java
@Override
public int hashCode() {
// 实现逻辑,通常是基于对象内部属性的组合计算
int result = yourProperty1;
result = 31 * result + (yourProperty2 != null ? yourProperty2.hashCode() : 0);
return result;
}
```
`equals()`方法则是比较两个对象是否相等,通常应满足以下性质:`a.equals(b)`如果且仅如果`b.equals(a)`并且`(!a.equals(null) && a == b)`或者`a.equals(c)`意味着`c.equals(a)`。常见的做法是检查对象是否完全相同,或者某些属性是否相等:
```java
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null || getClass() != obj.getClass())
return false;
YourClass that = (YourClass) obj;
// 检查对等的属性
return yourProperty1 == that.yourProperty1 &&
Objects.equals(yourProperty2, that.yourProperty2);
}
```
记住,当重写这两个方法时,需要保持一致性,即`a.equals(b)`的真值必须总是`a.hashCode()`等于`b.hashCode()`的结果。如果不一致,可能会导致哈希表的行为不可预测。
阅读全文