继承关系下的hashCode改写

按照JDK API上的描述,Object类中的hashCode方法的最重要的功能就是为了提高哈希表(例如 java.util.Hashtable 提供的哈希表)的性能。 JDK API上详细描述了如何改写hashCode方法:

  • 在 Java 应用程序执行期间,在对同一对象多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是将对象进行 equals 比较时所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。
  • 如果根据 equals(Object) 方法,两个对象是相等的,那么对这两个对象中的每个对象调用 hashCode 方法都必须生成相同的整数结果。
  • 如果根据 equals(java.lang.Object) 方法,两个对象不相等,那么对这两个对象中的任一对象上调用 hashCode 方法不 要求一定生成不同的整数结果。但是,程序员应该意识到,为不相等的对象生成不同整数结果可以提高哈希表的性能。

其中的第三条原则可以作为继承关系下改写hashCode的基本原则。 也就是说如果子类对象可以与父类对象进行内容上的比较,则不能改写子类的hashCode方法,让它直接继承父类的实现即可。实施要点如下:

  • 在父类中同时改写equals方法与hashCode方法;
  • 在子类中改写equals方法,保证子类对象可以与父类对象进行比较;
  • 子类中不改写hashCode方法,直接继承父类中改写的hashCode方法。

你可能感兴趣的:(Java基础)