C++ STL中顺序容器类型以及实现原理

1.顺序容器类型

vector支持随机访问
list支持快速插入与删除
deque双端队列
stack后进先出(LIFO)
queue先进先出(FIFO)
prority_queue优先队列

2.容器元素类型约束必须满足两个约束:

2.1 元素类型必须支持复制操作

2.2 元素类型必须支持赋值操作


3.vector

内存是连续分配的,支持随机访问,capacity函数是指容器的容量,size函数是指容器中元素的个数,当size == capacity 时,如果再向容器中插入新元素,则容器会自动分配一个更大的连续内存,然后把原来的数据复制到新的连续内存,这样保证了内存的连续性。其中容器支持程序员进行内存管理, reserve函数可以设置容器初始容量,和数组下表类似。

显然容器能支持随机访问,但是元素的插入和删除需要线性时间(除非插入到最后一个元素)。

当有元素或删除插入时,插入元素位置及插入元素之后的元素的迭代器将失效(保证内存连续性,后面元素前移)。若因为插入元素大于容量导致重新分配内存,则所有元素的迭代器失效。


4.list

list的实质是双向环形链表,不支持随机访问,顾内存不一定连续,但是list的插入与删除元素的时间复杂度都是O(1),并且除了删除的当前元素的迭代器会失效,其他元素迭代器不会失效。


5.deque

双端队列,支持随机访问,所需时间为常亮。内存分配是一块,一块的,将每一块连接起来,在开头和末端增加,删除元素效率与元素个数无关,内存自动管理。


6.stack

适配器,由deque实现。不能遍历所有元素,只能后进先出。


7.queue

适配器,由deque实现。不能遍历所有元素,只能先进先出。


8.priority_queue

适配器,由vector实现。不能遍历所有元素,只能访问优先级最高的第一个元素。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值