java 的集合有两类,一类是 List , 还有一类是 Set 。 前者有序可重复,后者无序不重复。 当我们在 set 中插入的时候怎么判断是否已经存在该元素呢,可以通过 equals 方法。 但是如果元素太多,用这样 的方法就会比较满。 于是有人发明了哈希算法来提高集合中查找元素的效率。 这种方式将集合分成若干个存储区域,每 个对象可以计算出一个哈希码,可以将哈希码分组,每组分别对应某个存储区域,根据一个对象的 哈希码就可以确定该对象应该存储的那个区域。 hashCode 方法可以这样理解:它返回的就是根据对象的内存地址换算出的一个值。 这样一来,当 集合要添加新的元素时,先调用这个元素的 hashCode 方法,就一下子能定位到它应该放置的物理 位置上。 如果这个位置上没有元素,它就可以直接存储在这个位置上,不用再进行任何比较了;如 果这个位置上已经有元素了,就调用它的 equals 方法与新元素进行比较,相同的话就不存了,不相 同就散列其它的地址。 这样一来实际调用 equals 方法的次数就大大降低了,几乎只需要一两次。
Hashcode 的作用
最新推荐文章于 2024-08-03 17:05:14 发布