JDK容器学习之Map : HashMap,TreeMap,LinkedHashMap对比
2017-11-12 13:14
447 查看
HashMap
, TreeMap
, LinkedHashMap
对比
1. 存储结构
HashMap 存储结构: 数组 + 链表 + 红黑树![](https://static.oschina.net/uploads/img/201709/24165810_toc1.png)
LinkedHashMap 存储结构 和HashMap 相同,区别是维护一个根据插入顺序保持的双向链表
![](https://static.oschina.net/uploads/img/201710/12094133_QqOB.jpg)
TreeMap 存储结构: 红黑树
![](https://static.oschina.net/uploads/img/201710/12094209_YS0Z.png)
2. 是否有序
HashMap 无序LinkedHashMap 根据插入先后顺序确定遍历顺序
TreeMap 有序,根据Key进行比较获取先后顺序
3. 迭代
HashMap 迭代从头开始遍历数组
若数组中该索引处为null,或者Node的next指向null,则扫描数组的下一位
若数组中该索引处非null,切Node的next指向另一个Node,则依次扫描Node的next元素,直到为null
示意图如下:
![](https://static.oschina.net/uploads/img/201709/28183845_9qzY.png)
LinkedHashMap 迭代
扫描内部的双向链表
从head指向的Node节点出发,依次扫描 after指向的下一个Node节点,直到最后一个
![](https://static.oschina.net/uploads/img/201710/12094247_AqTv.png)
TreeMap 迭代
因为TreeMap是红黑树,左孩子 < 根 < 右孩子,
所以按照树的中序遍历方式进行扫描,即先获取树的左孩子,然后是根,最后是右孩子
示意图如下:
![](https://static.oschina.net/uploads/img/201710/12094323_ab2G.jpg)
4. 应用场景&使用小建议
HashMap, LinkedHashMap, TreeMap 非线程安全,因此都不适用于多线程环境下希望有序的Map,考虑采用 LinkedHashMap, TreeMap
有自己的排序需求场景的,可以使用TreeMap
根据塞入Map的先后顺序进行排序的,可以使用 LinkedHashMap
其他普通kv接口存储,尽量采用
HashMap
若能确定Map的元素个数,在初始化时,显示指定容量大小,避免频繁的数组扩容
key的hash尽量分散,避免出现大量的hash碰撞(一般不自己覆盖 key的
hashcode方法,这个问题不太大)
有自定义排序需求时,使用
TreeMap
尽量保证结构的稳定,不会频繁出现添加删除的情况(因为会导致)
Map中不存在两个Key通过定义的比较器,返回0,即不存在类似
HashMap的碰撞情况
根据进入Map的先后确定遍历顺序,使用
LinkedHashMap
遵从
HashMap的使用规则
相关博文
JDK容器学习之HashMap (一) : 底层存储结构分析JDK容器学习之HashMap (二) : 读写逻辑详解
JDK容器学习之HashMap (三) : 迭代器实现
JDK容器学习之TreeMap (一) : 底层数据结构
JDK容器学习之TreeMap (二) : 使用说明
JDK容器学习之LinkedHashMap(一):底层存储结构分析
JDK容器学习之LinkedHashMap(二):迭代遍历的实现方式
II. Java分享,关注小灰灰Blog
![](https://static.oschina.net/uploads/img/201710/13203703_6IVg.jpg)
相关文章推荐
- JDK源码学习(5)-Map的性能比较,HashMap和TreeMap,ConcurrentSkipListMap
- JDK容器学习之HashMap (二) : 读写逻辑详解
- JDK容器学习之TreeMap (二) : 使用说明
- JDK容器与并发—Map—IdentityHashMap
- JAVA基础学习day16--集合三-Map、HashMap,TreeMap与常用API
- JAVA基础学习-集合三-Map、HashMap,TreeMap与常用API
- JDK容器与并发—Map—ConcurrentHashMap
- JDK容器学习之TreeMap (一) : 底层数据结构
- JDK容器与并发—Map—TreeMap
- java 容器类使用 Collection,Map,HashMap,hashTable,TreeMap,List,Vector,ArrayList的区别
- 【转】java 容器类使用 Collection,Map,HashMap,hashTable,TreeMap,List,Vector,ArrayList的区别
- java 容器类使用 Collection,Map,HashMap,hashTable,TreeMap,List,Vector,ArrayList的区别
- 黑马程序员_学习笔记:10) 集合框架2:Set(HashSet、TreeSet)、Map(Hashtable、HashMap、TreeMap)、Collections、Arrays
- JDK容器与并发—Map—HashMap
- java 容器类使用 Collection,Map,HashMap,hashTable,TreeMap,List,Vector,ArrayList的区别
- java容器学习,HashMap(jdk1.8)
- Java 容器类学习笔记1--了解Java提供的容器类List、ArrayList、Vector及map、HashTable、HashMap
- JDK源码学习(4)-java.util.HashMap、LinkedHashMap与TreeMap
- JAVA基础学习(十六)--集合三-Map、HashMap,TreeMap与常用API
- 【Java学习笔记】Map,TreeMap及HashMap