hashcode的问题 新手哈 过年好大家~
我在一本书中看到说成员变量的hashcode值以如下方式的到,我不明白这么做有什么效果?
------解决方案--------------------hasCode()当对象相等时hasCode()应该相等。这样可以让值不一样的对象返回不同的hasCode,但不是绝对的,也就是做初步的判断。当hasCode值相等时,对象不一定相等(调用equals()方法进一步验证);当对象相等时,hasCode()的返回值一定是相同的。当然,这得你自己重写这两个方法进行保证。
------解决方案--------------------
------解决方案--------------------效果就是降低hashCode发生碰撞的概率
------解决方案--------------------就是返回一个值,这个值相等的话,那么两个对象就是相等的,否则不一定相等,需要调用equals()进行进一步确认
------解决方案--------------------
------解决方案--------------------hashCode的计算方法当然不是固定的,我们是可以自己进行定义的。lz表中列出的计算方法是能够比较好的保证hashCode的使用特性的,因为我们要尽可能的保证不同的对象计算出的hashCode值是不同的。
我们完全可以自己简单的定义hashCode的计算方法,比如都返回1,或者返回根据某个属性计算出来的值,但这样就会使hash的效率变低