Google首席Java架构师Joshua Bloch在他的著作《Effective Java》中提出了一种简单通用的hashCode算法

  1. 初始化一个整形变量,为此变量赋予一个非零的常数值,比如int result = 17;
  2. 选取equals方法中用于比较的所有域,然后针对每个域的属性进行计算:

      (1) 如果是boolean值,则计算f ? 1:0

      (2) 如果是byte\char\short\int,则计算(int)f

      (3) 如果是long值,则计算(int)(f ^ (f >>> 32))

      (4) 如果是float值,则计算Float.floatToIntBits(f)

      (5) 如果是double值,则计算Double.doubleToLongBits(f),然后返回的结果是long,再用规则(3)去处理long,得到int

      (6) 如果是对象应用,如果equals方法中采取递归调用的比较方式,那么hashCode中同样采取递归调用hashCode的方式。  否则需要为这个域计算一个范式,比如当这个域的值为null的时[……]

    阅读全文