当前位置: 代码迷 >> J2SE >> 在java自动生成hashCode代码有关问题? 请大神赐教
  详细解决方案

在java自动生成hashCode代码有关问题? 请大神赐教

热度:30   发布时间:2016-04-24 00:23:35.0
在java自动生成hashCode代码问题? 请大神赐教
我定义了一个teacher类

Java code
private String name;private int age;//下面是自动生成的hashCode@Override    public int hashCode() {        final int prime = 31;        int result = 1;        result = prime * result + age;        result = prime * result + ((name == null) ? 0 : name.hashCode());        return result;    }


result = prime * result + age; //result的值肯定会被下面的覆盖掉
result = prime * result + ((name == null) ? 0 : name.hashCode());
为什么这么写。

------解决方案--------------------
并不会被下面所覆盖掉啊?
result = prime * result + ((name == null) ? 0 : name.hashCode());
注意到这句话中,result也参与了计算,而且放大了31倍。

结合之前的计算,两句话合并相当于是:
result = prime * (prime * result + age) + ((name == null) ? 0 : name.hashCode());
代入数字的话也即:
return 31 * (31 + age) + ((name == null) ? 0 : name.hashCode());

------解决方案--------------------
覆盖掉就覆盖掉呗,你要先了解一下 hashCode 的作用!

hashCode 并不是保证唯一使用的,只是对对象作一个数字上的标记而已。

一般使用一个素数来计算 hashCode
  相关解决方案