重写hashCode方法
时间: 2023-09-07 17:17:50 浏览: 104
复写hashCode()方法,和equasl()方法
在Java中,hashCode方法是用于获取对象的哈希码的方法,它的返回值是int类型。默认情况下,hashCode方法返回的哈希码是根据对象的内存地址计算出来的。但是,如果我们在类中重写了hashCode方法,就可以根据我们自己的需求来计算哈希码了。
在重写hashCode方法时,需要遵循以下原则:
1. 如果两个对象的equals方法返回true,则它们的hashCode方法返回值必须相同;
2. 如果两个对象的equals方法返回false,则它们的hashCode方法返回值不一定不同,但是不同的hashCode值能够提高哈希表的性能;
3. hashCode方法不能依赖于对象的内部状态,因为对象的内部状态改变时,hashCode值也会改变。
重写hashCode方法的一般步骤如下:
1. 定义一个int类型的变量result,并初始化为一个非零值,比如17;
2. 将对象中每个重要的域(即影响对象相等性的域)的hashCode值计算出来,并将这些值组合起来,一般使用乘法和加法混合的方式实现。例如,如果对象有两个重要的域a和b,则可以使用result = 31 * result + a.hashCode() + b.hashCode();
3. 返回result的值。
下面是一个示例,展示了如何重写hashCode方法:
```
public class Person {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public int hashCode() {
int result = 17;
result = 31 * result + name.hashCode();
result = 31 * result + age;
return result;
}
// 省略equals方法
}
```
在这个例子中,我们根据对象中的两个重要域name和age来计算哈希码。我们使用17来初始化result变量,然后将name的hashCode值和age的值分别乘以31后加到result中,最后返回result的值。
阅读全文