C/C++教程

C++ STL库之deque解析

本文主要是介绍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
这篇关于C++ STL库之deque解析的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!