我在一本书中看到说成员变量的hashcode值以如下方式的到,我不明白这么做有什么效果?

解决方案 »

  1.   

    hasCode()当对象相等时hasCode()应该相等。这样可以让值不一样的对象返回不同的hasCode,但不是绝对的,也就是做初步的判断。当hasCode值相等时,对象不一定相等(调用equals()方法进一步验证);当对象相等时,hasCode()的返回值一定是相同的。当然,这得你自己重写这两个方法进行保证。
      

  2.   


    你的问题是什么?是hashcode的作用还是hashcode生成的方式?
      

  3.   

    效果就是降低hashCode发生碰撞的概率
      

  4.   


    这表里对每种类型的数据都在做转换,就是没明白为何还要计算一下?这么计算一下就是hashcode了?
      

  5.   

    就是返回一个值,这个值相等的话,那么两个对象就是相等的,否则不一定相等,需要调用equals()进行进一步确认
      

  6.   

    这几个转换是固定的么?有没有其他的计算hashcode的途径?那本书接下来在上面计算出的hashcode值前面,分别还加上了个系数,系数是任意的质数。这优势什么原理?
      

  7.   


    hashcode 规定是int,所以必然需要做转换。转换有两个目标:1、转换代价低;2、重复率低。
      

  8.   

    hashCode的计算方法当然不是固定的,我们是可以自己进行定义的。lz表中列出的计算方法是能够比较好的保证hashCode的使用特性的,因为我们要尽可能的保证不同的对象计算出的hashCode值是不同的。
    我们完全可以自己简单的定义hashCode的计算方法,比如都返回1,或者返回根据某个属性计算出来的值,但这样就会使hash的效率变低