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

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、付费专栏及课程。

余额充值