面试记录:Map 和 Set 的区别

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。

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]中的代码展示了如何使用std::unordered_map来创建一个键值对的容器,并使用Print函数打印出容器中的元素。其中,m1是一个std::unordered_map对象,包含了键值对{1, 10}, {2, 20}, {3, 30}。通过调用Print函数,我们可以看到容器中的元素被正确地打印出来。 引用\[2\]中的内容介绍了std::set和std::map中的lower_bound和upper_bound函数。lower_bound函数返回setmap中第一个大于等于给定值的迭代器,而upper_bound函数返回第一个大于给定值的迭代器。这两个函数的设计可能与我们对lower和upper的理解有所不同,但是它们的功能是根据给定值在容器中查找元素的位置。 引用\[3\]中的代码展示了如何使用迭代器来遍历std::unordered_map容器中的元素。通过使用begin函数获取起始迭代器,然后使用end函数获取结束迭代器,我们可以使用迭代器来遍历容器中的所有元素。在代码中,使用了两种类型的迭代器,即普通迭代器和常量迭代器,分别用于修改和只读访问容器中的元素。 综上所述,std::map和std::set是C++标准库中的关联容器,它们提供了不同的功能和特性,可以根据具体的需求选择使用。 #### 引用[.reference_title] - *1* *3* [std::unordered_map](https://blog.csdn.net/TimerSea/article/details/128067616)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [STL中std::set、std::map的lower_bound和upper_bound](https://blog.csdn.net/qq_41883523/article/details/115798756)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值