hashCode(散列码)是由对象导出的一个整型值。散列码是没有规律的。如果x和y是两个不同的对象,x.hashCode()和y.hashCode()基本不会相同
由于hashCode方法定义在Object类中,因此每一个对象都有一个默认的散列码,其值为对象的存储地址
public static void main(String[] args) {
StringBuilder str1 = new StringBuilder("ok");
StringBuilder str2 = new StringBuilder("ok");
System.out.println(str1.hashCode());
System.out.println(str2.hashCode());
}
运行结果: 2018699554
1311053135
在一些类中对HashCode方法进行了重写,比如String类,它的散列值是根据内容导出的,比如:
public static void main(String[] args) {
String str1 = "ok";
String str2 = "ok";
System.out.println(str1.hashCode());
System.out.println(str2.hashCode());
}
运行结果: 3548
3548
我们可以看出如果字符串的内容一样,那么它的散列值也是一样的。
HashCode方法的返回值一般是一个整型的数值(也可以是负数),所以一般我们也可以自己定义HashCode方法,合理的组合各个实例域的散列码,以便能够让各个对象的散列产生的散列值更加的均匀。例如:
public class Animal {
private String name ;
private int age;
public int hashCode() {
return 7*name.hashCode()
+11*Integer.hashCode(age);
}
}
在Objects类(注意不是Object)中,它的HashCode方法在参数为null的时候会返回一个0,否则会返回对参数调用HashCode的结果。利用这一点我们可以将上边的代码进行优化。
public class Animal {
private String name ;
private int age;
public int hashCode() {
return 7*Objects.hashCode(name)
+11*Integer.hashCode(age);
}
}
在Objects类中,还可以使用hash方法一次性传多个参数,分别为各个参数调用不同的Objects.hashCode方法,比如:
public int hashCode() {
return Objects.hash(name,age);
}
在一个类中如果重写了equals方法,那么就必须重新定义HashCode方法,Equals方法与HashCode方法的定义必须一致:如果x.equals(y)返回结果为true,那么x.hashCode()和y.hashCode()就必须返回相同的值。