jdk1.8中HashMap扩容和JDK1.7HashMap扩容的区别说明
下文笔者讲述HashMap在jdk1.8版本中的扩容方法分享,如下所示
HashMap什么时候进行扩容---如何扩容呢?
jdk1.8和jdk1.7在HashMap的扩容上步骤一摸一样 只是JDK1.8引入了红黑树
JDK1.8HashMap和JDK1.7HashMap扩容的区别
1.两者底层存储结构不同: 1.7是数组+链表 1.8是数组+链表+红黑树结构; 2. jdk1.7中当哈希表为空时 会先调用inflateTable()初始化一个数组 jdk1.8则是直接调用resize()扩容 3. 插入键值对的put方法的区别 1.8中会将节点插入到链表尾部 1.7中是采用头插 4. jdk1.7中的hash函数对哈希值的计算直接使用key的hashCode值 jdk1.8中则是采用key的hashCode异或上key的hashCode进行无符号右移16位的结果 避免了只靠低位数据来计算哈希时导致的冲突 计算结果由高低位结合决定,使元素分布更均匀; 5. 扩容时1.8会保持原链表的顺序 1.7会颠倒链表的顺序 1.8是在元素插入后检测是否需要扩容 1.7则是在元素插入前 6. jdk1.8是扩容时通过hash&cap==0将链表分散 无需改变hash值 jdk1.7通过更新hashSeed来修改hash值达到分散的目的 7. 扩容策略 jdk1.7中是只要不小于阈值就直接扩容2倍 jdk1.8的扩容策略会更优化 当数组容量未达到64时,以2倍进行扩容 超过64之后若桶中元素个数不小于7就将链表转换为红黑树 但如果红黑树中的元素个数小于6就会还原为链表 当红黑树中元素不小于32的时候才会再次扩容。相关阅读:
HashMap什么时候进行扩容---如何扩容呢?
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。