HashMap中的transient关键字解惑
程序员文章站
2022-06-04 19:28:24
...
看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 来修饰不希望序列化的属性。
推荐阅读
-
实例解析Java中的synchronized关键字与线程安全问题
-
Java中new关键字和newInstance方法的区别分享
-
C#中的yield关键字的使用方法介绍
-
Android源码中final关键字的用法及final,finally,finalize的区别
-
百度搜索框中关键字的历史记录怎么彻底删除?
-
java中Hashtable和HashMap的区别分析
-
深入解析Python编程中super关键字的用法
-
java 中的static关键字和final关键字的不同之处
-
Java中对HashMap的深度分析
-
浅谈.net core 注入中的三种模式:Singleton、Scoped 和 Transient