本文主要是介绍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也称之为映射表,或者称之为字典。
这篇关于STL源码剖析 关联式容器的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!