HashCode是什么
HashCode是Object类中的一个方法,由于任何类均为Object类的间接子类,所以均继承方法public int hashCode(),该方法返回的值一般是JVM虚拟机通过将该对象的内部地址转换成一个10进制整数来显现的,这样能保证每个对象的哈希码值不一样。
需要注意的几点
1.每个对象都有一个唯一的物理地址,是确定的、唯一的。而HashCode通过JVM将对象的内存地址转换成的是一个逻辑地址,是不确定的、不唯一的。
2.一般情况下,每个对象的Hash值是不同的,但是由于哈希值的底层是通过Hash算法所得出的,所以对于不同对象来说,他们是可以通过强制手段使得Hash值相同的。
3.String类的HashCode是通过一种特殊的算法得出的,只要字符串内容相同,返回的Hash值也相同。
4.Integer类的hashCode返回的哈希值是Integer对象里所包含的那个整数的数值,例如Integer i1=new Integer(100),i1.hashCode的值就是100 。由此可见,2个一样大小的Integer对象,返回的哈希值也一样。
总结
当我们比较基本数据类型时,优先使用==比较,当比较字符串内容和封装类时,优先使用equals比较。
当两个对象的HashCode相同时,equals不一定为true,如果两个不同的对象通过特殊的算法使得他们返回的hash值相同,但是他们之间的equals比较仍然为false。