HashMap中的transient关键字解惑

看HashMap源码的时候,看到如下定义

transient Node<K,V>[] table;
transient Set<Map.Entry<K,V>> entrySet;
transient int size;
transient int modCount;

transient关键字有什么作用,HaspMap中为什么要使用呢?
首先来了解transient关键字的作用
被transient修饰的属性,在序列化时,将不会被序列化。
那为什么HashMap中要用transient修饰呢?
1、因为 HashMap 中的存储数据的数组数据成员中,数组还有很多的空间没有被使用,没有被使用到的空间被序列化没有意义。所以需要手动使用 writeObject() 方法,只序列化实际存储元素的数组。
2. 在Effective Java 3nd, Item87中有提到

例如,考虑到散列表(hash table)的情形。它的物理表示法是一些列包含“键-值”项的散列桶。到底一个项(key)被放在哪个桶中,这是该键的hash code的确定,一般情况下,不同的JVM实现不保证会有相同的hash code。实际上,即使是相同的JVM实现中,也无法保证每次运行都一样。因此,对于散列表而言,接受默认的序列化形式将会构成一个严重的bug。对散列表对象进行序列化和反序列化操作所产生的的对象,其约束关系会遭到严重的破坏。

再结合HashMap.get()/put()的源码知道, 读写Map是根据Object.hashcode()来确定从哪个bucket读/写. 而Object.hashcode()是native方法, 不同的JVM里可能是不一样的。所以用transient 来修饰不希望序列化的属性。

你可能感兴趣的:(集合)