专栏/面试记录:Map 和 Set 的区别

面试记录:Map 和 Set 的区别

2022年09月28日 11:48--浏览 · --喜欢 · --评论
粉丝:270文章:12

Map 是字典,Set 是集合

Map

  • 字典是键值对保存数据,可以通过 key 进行取值,也可以使用迭代器遍历内容

  • Map中的Key不允许有重复(确切的讲是不允许内容中有equals方法比较后返回true的两个成员)

  • 实现类有 HashMap、TreeMap

Set

  • Set 可以用迭代器等遍历内容

  • Set 集合最基本的特征是不允许内容有重复(确切的讲是不允许内容中有equals方法比较后返回true的两个成员)

  • 实现类有 HashSet、LinkedHashSet 、TreeSet

HashMap 和 TreeMap

HashMap

最常用的实现类,底层实现是数组+链表+红黑树(jdk7中没有红黑树)
这里主要说明jdk8的HashMap
在往 HashMap 中首次 put 元素时(没有在生命时指明长度),HashMap 会在内部 new 一个长度为16的数组,然后计算 put 元素的hashcode,并将这个值与数组长度进行取余,随后就会将这个元素放入这个取余的值所对应的数组索引位置。
后续的 put 操作类似,如果出现了取余后得到的值所在的数组索引位置已经有元素的情况,则会对两者进行 equals 比较,如果结果为true,则不放入,否则将使用链表的结构将内容添加到数组上第一个内容的后面(如果链表上也有元素的话也会逐个比较),当链表长度大于8时,会将链表转化为红黑树。
同时,这个长度为16的数组也会进行扩容,因为使用位运算进行扩容的容量计算,所以数组每次扩容长度都会增加一倍。至于这个数组什么时候会扩容,这里就不写这么深了。

TreeMap

底层使用红黑树实现,数据在插入时会对key自动进行排序构建成红黑树,查询时按照红黑树的查询规则查询,红黑树就不展开写了。

HashSet、LinkedHashSet 和 TreeSet

HashSet

底层使用HashMap实现,用HashMap中Key不可重复的特性,因为HashMap中key的存放是无序的(计算哈希值,哈希冲突加链表还能造成红黑树,肯定无序),所以 HashSet 里的元素也是无序的。

LinkedHashSet

和 HashSet 类似,是 HashSet 的子类,和 HashSet 的区别在于 LinkedHashSet 会维护一个保存元素插入顺序的双向链表,这样就实现了里面的元素保持插入顺序(实际上保存位置仍旧是无序的)

TreeSet

底层使用 TreeMap 实现的 Set。

补充:以上提到的所有实现类都是线程不安全的。


投诉或建议