散列码是由对象导出的一个整型值。散列码是没有规律的。
如果重新定义equals方法,就必须重新定义hashCode方法,以便用户可以讲对象插入到散列表中。
equals与hashCode的定义必须一致:如果x.equals(y)返回true,那么x.hashCode()就必须与y.hashCode()具有相同的值。例如,如果用定义Employee.equals比较雇员的ID,那么hashCode方法就需要散列ID,而不是雇员的姓名或储存地址。
//java.util.Object
int hashCode()
/*返回对象的散列码。散列码可以是任意的整数,包括整数或负数。两个相等的对象要求返回相等的散列码。*/
//java.util.Objects
static int hash(Object... objects)
/*返回一个散列码,由提供的所有对象的散列码组合而得到。*/
static int hashCode(Object a)
/*如果a为null返回0,否则返回a.hashCode()。*/
//java.lang.(Integer|Long|Short|Byte|Double|Float|Character|Boolean)
static int hashCode(int|long|short|byte|double|float|char|boolean value)
/*返回给定值的散列码*/
//java.util.Arrays
static int hashCode(type[] a)
/*计算数组a的散列码*/
散列码与equals方法
本文探讨了散列码的概念及其在散列表中的作用。强调了当覆盖equals方法时,hashCode方法也应被覆盖以保持一致性。介绍了Java中散列码的实现方式,包括Object.hashCode(), Objects.hash()等。
1664

被折叠的 条评论
为什么被折叠?



