STL源码剖析 关联式容器

  • STL关联式容器以set(集合) 和 map(映射表)两大类,以及对应的衍生体构成,比如mulyiset(多键集合) multimap(多键映射表) ,容器的底层均基于红黑树
  • RB-Tree也是一个独立的容器,但是不对外开放
  • 此外还提供了标准之外的关联式容器 hash table散列表,以及基于hash table完成的hash_set 散列集合、hash_map散列映射表、hash_multiset散列多键集合、hash_multimap散列多键映射表

关联式容器

  •  类似关联式数据库,每一笔数据均由键值和实值两部分组成,当元素被插入到关联式数据库的时候,容器的内部结构不管是RB-tree还是hash_table便依照键值的大小使用某种特定的规则将这个元素放置在适当的位置
  • 关联式容器 没有所谓的头尾的概念(比如极值出现在头或者尾)、push_back()  push_front() pop_back() pop_front() begin() end() 均不具备
  • 关联式容器的内部是一个 balance binary tree 平衡二叉树,主要目的是为了获得良好的搜索的效率。但是  balance binary tree 平衡二叉树包含很多的类型,比如AVL tree、rb-tree 、AA-tree 但是使用最为广泛的是RB-Tree红黑树
  • set的键值就是实值,而map的键值和实值是可以分开的,形成一种映射的关系。所以map也称之为映射表,或者称之为字典。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值