java学习之为什么要有 hashCode

 Java 序列化中如果有些字段不想进行序列化,怎么办?

 对于不想进行序列化的变量,使用 transient 关键字修饰。

  transient 关键字的作用是:阻止实例中那些用此关键字修饰的的变量序列化;当对象被反序列化时,被 transient  

修饰的变量值不会被持久化和恢复。transient 只能修饰变量,不能修饰类和方法。

 java为什么要有 hashCode

  我们先以“HashSet 如何检查重复”为例子来说明为什么要有 hashCode: 当你把对象加入 HashSet 时,HashSet 会先计算对象的  

hashcode 值来判断对象加入的位置,同时也会与该位置其他已经加入的对象的 hashcode 值作比较,如果没有相符的 hashcode,HashSet  

会假设对象没有重复出现。但是如果发现有相同 hashcode 值的对象,这时会调用 equals()方法来检查 hashcode  

相等的对象是否真的相同。如果两者相同,HashSet 就不会让其加入操作成功。如果不同的话,就会重新散列到其他位置。(摘自我的 Java 启蒙书《Head  

first java》第二版)。这样我们就大大减少了 equals 的次数,相应就大大提高了执行速度。

  通过我们可以看出:hashCode() 的作用就是获取哈希码,也称为散列码;它实际上是返回一个 int  

整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。hashCode()在散列表中才有用,在其它情况下没用。在散列表中 hashCode()  

的作用是获取对象的散列码,进而确定该对象在散列表中的位置。

posted @ 2021-11-04 12:03  指尖上的代码go  阅读(255)  评论(0)    收藏  举报