橙小张的Java后端学习之路程序员Java学习笔记

String中hashCode算法

2017-07-06  本文已影响50人  橙小张

说起hashCode是,就先说下HashCode一些关键点:
1、hashCode的存在主要是用于查找的快捷性,如Hashtable,HashMap等,hashCode是用来在散列存储结构中确定对象的存储地址的;
2、如果两个对象相同,就是适用于equals(Java.lang.Object) 方法,那么这两个对象的hashCode一定要相同;
3、如果对象的equals方法被重写,那么对象的hashCode也尽量重写,并且产生hashCode使用的对象,一定要和equals方法中使用的一致,否则就会违反上面提到的第2点;
4、两个对象的hashCode相同,并不一定表示两个对象就相同,也就是不一定适用于equals(java.lang.Object) 方法,只能够说明这两个对象在散列存储结构中,如Hashtable,他们“存放在同一个篮子里”

通过一段代码来测试下:


image.png

String的hashCode方法的代码

image.png image.png

自己实现的话可以这样

image.png

总结:

上一篇下一篇

猜你喜欢

热点阅读