关联式容器也是用来存储数据的,与序列式容器不同的是,其里面存储的是<key, value>结构的键值对,在数据检索时比序列式容器效率更高。
STL总共实现了两种不同结构的管理式容器:
- 树型结构
- 哈希结构
树型结构的关联式容器主要有四种:map、set、multimap、multiset。
这四种容器的共同点是:底层使用平衡搜索树(即红黑树),容器中的元素是一个有序的序列。
set特点:
- set是按照一定次序存储元素的容器,默认升序,使用set的迭代器遍历set中的元素,可以得到有序序列
- set中的元素不可以重复(set可以天然去重)
- set容器通过key访问单个元素的速度通常比unordered_set容器慢,因为哈希表的平均访问时间复杂度是O(1),但它们允许根据顺序对子集进行直接迭代
- 与map/multimap不同,map/multimap中存储的是真正的键值对<key, value>,set中只放value,但在底层实际存放的是由<value, value>构成的键值对
map特点:
- 在map中,键值key通常用于排序和惟一地标识元素,而值value中存储与此键值key关联的内容
- 在map的内部,key与value通过成员类型value_type绑定在一起,为其取别名称为pair: typedef pair value_type;
- 在内部,map中的元素总是按照键值key进行比较排序的
- map中通过键值访问单个元素的速度通常比unordered_map容器慢
- 注意:在元素访问时,operator[]和at(),都是通过key找到与key对应的value然后返回其引用。不同的是:当key不存在时,operator[]用默认value与key构造键值对然后插入,返回该默认value,at()函数直接抛异常
// 使用map迭代器进行遍历
void test()
{
map<int, char> m;
// 范围for尽量使用&:避免深拷贝带来的不必要开销
for (auto& e : m)
cout << e.first << "-->" << e.second << endl;
}
multiset特点:
- multiset是按照特定顺序存储元素的容器,与set的区别是,multiset中的元素可以重复,set是中value是唯一的
- multiset的作用:可以对元素进行排序,默认升序
- multiset中在底层中存储的是<value,value>的键值对,底层结构为二叉搜索树(红黑树)
multimap特点:
- 注意:multimap和map的唯一不同就是:map中的key是唯一的,而multimap中key是可以重复的
- multimap中没有重载operator[]操作