JAVA随笔

JDK容器学习之Map : HashMap,TreeMap,Li

2017-11-06  本文已影响74人  一灰灰blog

HashMap, TreeMap, LinkedHashMap 对比

1. 存储结构

HashMap 存储结构: 数组 + 链表 + 红黑树

image

LinkedHashMap 存储结构 和HashMap 相同,区别是维护一个根据插入顺序保持的双向链表

LinkedHashMap结构

TreeMap 存储结构: 红黑树

TreeMap结构

2. 是否有序

HashMap 无序

LinkedHashMap 根据插入先后顺序确定遍历顺序

TreeMap 有序,根据Key进行比较获取先后顺序


3. 迭代

HashMap 迭代

示意图如下:

image

LinkedHashMap 迭代

image

TreeMap 迭代

因为TreeMap是红黑树,左孩子 < 根 < 右孩子,

所以按照树的中序遍历方式进行扫描,即先获取树的左孩子,然后是根,最后是右孩子

示意图如下:

image

4. 应用场景&使用小建议

  1. HashMap, LinkedHashMap, TreeMap 非线程安全,因此都不适用于多线程环境下

  2. 希望有序的Map,考虑采用 LinkedHashMap, TreeMap

  1. 其他普通kv接口存储,尽量采用 HashMap
  1. 有自定义排序需求时,使用 TreeMap
  1. 根据进入Map的先后确定遍历顺序,使用 LinkedHashMap

相关博文

关注更多

扫一扫二维码,关注小灰灰blog

小灰灰blog
上一篇 下一篇

猜你喜欢

热点阅读