JDK容器学习之Map: HashMap,TreeMap,LinkedHashMap对比小结

HashMap, TreeMap, LinkedHashMap 对比

1. 存储结构

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

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

LinkedHashMap结构

TreeMap 存储结构: 红黑树数据结构

TreeMap结构


2. 是否有序

HashMap 无序多线程

LinkedHashMap 根据插入前后顺序肯定遍历顺序学习

TreeMap 有序,根据Key进行比较获取前后顺序.net


3. 迭代

HashMap 迭代线程

  • 从头开始遍历数组
  • 若数组中该索引处为null,或者Node的next指向null,则扫描数组的下一位
  • 若数组中该索引处非null,切Node的next指向另外一个Node,则依次扫描Node的next元素,直到为null

示意图以下:code

LinkedHashMap 迭代blog

  • 扫描内部的双向链表
  • 从head指向的Node节点出发,依次扫描 after指向的下一个Node节点,直到最后一个

TreeMap 迭代排序

由于TreeMap是红黑树,左孩子 < 根 < 右孩子,

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

示意图以下:


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

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

  2. 但愿有序的Map,考虑采用 LinkedHashMap, TreeMap

  • 有本身的排序需求场景的,可使用TreeMap
  • 根据塞入Map的前后顺序进行排序的,可使用 LinkedHashMap
  1. 其余普通kv接口存储,尽可能采用 HashMap
  • 若能肯定Map的元素个数,在初始化时,显示指定容量大小,避免频繁的数组扩容
  • key的hash尽可能分散,避免出现大量的hash碰撞(通常不本身覆盖 key的 hashcode 方法,这个问题不太大)
  1. 有自定义排序需求时,使用 TreeMap
  • 尽可能保证结构的稳定,不会频繁出现添加删除的状况(由于会致使)
  • Map中不存在两个Key经过定义的比较器,返回0,即不存在相似 HashMap 的碰撞状况
  1. 根据进入Map的前后肯定遍历顺序,使用 LinkedHashMap
  • 听从 HashMap 的使用规则

相关博文

关注更多

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

小灰灰blog

相关文章
相关标签/搜索