C++ STL库之deque解析

deque v.s. vector

  • deque 允许使用常数项时间对头端进行元素的插入和删除操作
  • deque 没有容量的概念,因为它是动态的以分段连续空间组合而成,随时可以增加一段新的空间并链接起来,deque 没有必须要提供所谓的空间保留(reserve)功能。
  • 而vector需要旧空间不足而重新配置一块更大空间,然后复制元素,再释放旧空间。

DEQUE容器的实现原理

deque 是由一段一段的定量的连续空间构成。一旦有必要在 deque 前端或者尾端增加新的空间,便配置一段连续定量的空间,串接在 deque 的头端或者尾端。Deque 最大的工作就是维护这些分段连续的内存空间的整体性的假象,并提供随机存取的接口,避开了重新配置空间,复制,释放的轮回,代价就是复杂的迭代器架构。

deque 是分段连续内存空间,有中央控制器,维持整体连续的假象。中控器中每一个节点都是一个指针,指向真正的缓存区

 

 

 Reference

  1. https://blog.csdn.net/u014038273/article/details/78158684
posted @ 2022-03-25 00:28  cancantrbl  阅读(131)  评论(0编辑  收藏  举报