推荐你看一下这篇文章,对理解hashcode有帮助《Java 理论与实践: 哈希
有效和正确定义hashCode()和equals()》
http://www-128.ibm.com/developerworks/cn/java/j-jtp05273/
Top
3 楼liuguangliang(小刀刘)回复于 2006-09-12 22:51:29 得分 0
hashcode();是一个方法,主要是用来标识一个对象的。Top
4 楼liuguangliang(小刀刘)回复于 2006-09-12 22:52:42 得分 0
public int hashCode()返回该对象的哈希码值。支持该方法是为哈希表提供一些优点,例如,java.util.Hashtable 提供的哈希表。
hashCode 的常规协定是:
在 Java
应用
程序执行期间,在同一对象上多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是对象上 equals 比较中所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。
如果根据 equals(Object) 方法,两个对象是相等的,那么在两个对象中的每个对象上调用 hashCode 方法都必须生成相同的整数结果。
以下情况不 是必需的:如果根据 equals(java.lang.Object) 方法,两个对象不相等,那么在两个对象中的任一对象上调用 hashCode 方法必定会生成不同的整数结果。但是,程序员应该知道,为不相等的对象生成不同整数结果可以提高哈希表的性能。
实际上,由 Object 类定义的 hashCode 方法确实会针对不同的对象返回不同的整数。(这一般是通过将该对象的内部地址转换成一个整数来实现的,但是 JavaTM 编程语言不需要这种实现技巧。)
Top
5 楼treeroot(旗鲁特)回复于 2006-09-13 09:08:08 得分 0
哈西表提供最快的精确检索能力,它需要哈西值,所以有这个方法
同时我们可以看出哈西表这种数据结构有多么的重要