[Java开发之路](22)hashcode

散列码(hash code)是由对象导出的一个整型值。散列码是没有规律的。如果x和y是两个不同的对象,x.hashCode()与y.hashCode()基本上是不会相同的。

  
  
  
  
  1.    public int hashCode() {
  2.        int h = hash;
  3.        if (h == 0 && value.length > 0) {
  4.            char val[] = value;
  5.            for (int i = 0; i < value.length; i++) {
  6.                h = 31 * h + val[i];
  7.            }
  8.            hash = h;
  9.        }
  10.        return h;
  11.    }

由于hashCode方法定义在Objects类中,因此每个对象都有一个默认的散列码,其值为对象的存储地址

   
   
   
   
  1.    @Test
  2.    public void test2(){
  3.        String str = "abc";
  4.        System.out.println("str hashcode : " + str.hashCode());
  5.        String str2 = new String("abc");
  6.        System.out.println("str2 hashcode : " + str2.hashCode() + "  address : " + str2.);
  7.        System.out.println(" str == str2 : " + (str == str2));
  8.        StringBuilder stringBuilder = new StringBuilder(str);
  9.        System.out.println("stringBuilder : " + stringBuilder.hashCode());
  10.        StringBuilder stringBuilder2 = new StringBuilder(str2);
  11.        System.out.println("stringBuilder2 : " + stringBuilder2.hashCode());
  12.        System.out.println(" stringBuilder == stringBuilder2 : " + (stringBuilder == stringBuilder2));
  13.    }

我们可以看到str和str2有相同的散列码,这是因为字符串的散列码是由内容导出的。而字符串缓冲stringBuilder和stringBuilder2却有着不同的散列码,这是因为在StringBuilder类中没有定义hashCode方法,它的散列码是由Objects类的默认hashcode方法导出的对象存储地址

hashcode方法应该返回一个整型值(也可以是负数),并合理的组合实例域的散列码,以便能够让各个不同的对象产生散列码更加均匀。

在Java7中进行了改进。首先,最好使用null安全的方法Objects.hashCode。如果参数为null,这个方法会返回0,否则返回对参数调用hashCode的结果。

还有更好的,需要组合多个散列值时,可以调用Objects.hash并提供多个参数,这个方法会对各个参数调用Objects.hashCode,并组合这些散列值。

   
   
   
   
  1. public int hashCode(){
  2.    return Objects.hash(name,salary,hireDay);
  3. }

Equals与hashCode的定义必须一致:如果x.equals(y)返回true,那么x.hashCode()就必须与y.hashCode()具有相同的值。







你可能感兴趣的:(java开发之路)