STL 配置器和容器,序列容器和关联容器总结

本文总结了STL中的容器类型,包括序列容器如vector、list、deque、stack、queue、heap和priority-queue,以及关联容器如set、map、multiset和multimap。序列容器中,vector适合随机访问,list适合频繁插入删除,deque则结合两者特点。stack和queue是基于deque的适配器。关联容器内部基于RB-Tree或Hash表,提供高效的key-value查找。对于迭代器,序列容器在插入删除后可能使迭代器失效,而关联容器的迭代器通常在操作后仍有效。
摘要由CSDN通过智能技术生成

STL中定义了许多容器类型,这些类型在C++中非常实用。但是很多人却并没有理解为什么叫配置器和容器,下面做个总结:

  • 序列容器:数组、vector、list、deque、stack、queue、heap、priority-queue。这些类型存放的内容为value,并且在排放的逻辑上是一种线性结构。其中,stack、queue为配置器。为什么称他们为配置器,而不是容器呢?配置器的意思:修改某物接口,形成另一风貌的,称谓adapter(配置器)。这就需要我们深入源码去逐一分析。 
  1. vector: 代码实现为一块连续的内存,可以理解为动态扩张的array,具有随机访问的特性。但是不适合频繁的随机插入、删除。
  2. list: 代码实现为双向链表结构,适合频繁随机插入、删除的操作。
  3. deque: 双向操作队列,代码实现比较复杂。利用一个map表(非STL的map,而是类似于指针数组),用作块映射,每个地址都指向一块连续的内存,每个连续内存大小相同。deque内部通过迭代器start,finish分别指向第一个块和最后一个块。
  4. stack:栈的特性是单向操作,同一个入口、出口,FILO。在STL中,由于deque具有双向操作的功能,所以没必要单独再去实现一套stack。只需要在deque的基础上封闭一端的操作,就具备了stack的特性。因此,stack是一个adapter。
  5. queue:队列的特性是FIFO,一端进
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值