std::deque底层实现

 一.概述-类分析

        每一个容器继承自己的base版本,base中储存重要的数据结构,deque主要由中控数组指针,中控数组大小以及首尾迭代器构成。这些元素放置在_Deque_impl<_Tp>类中,这个类公有继承allocator类型(实际上这样设计不好,不能说他的类型与allocator有关)。deque实际上表面是线性连续的,实质是分段的。主要通过迭代器模拟了连续容器的特点,对都是迭代器的功劳。迭代器元素如_Deque_iterator<_Tp>所示。主要保存元素分界,cur读写模拟头,以及指向中控数组的指针。

内部分布如下:

二.deque迭代器如何模拟连续空间

        deque迭代器主要通过操作符重载去模拟连续空间的特点,主要通过判断加减访问操作是否跨越缓冲区,跨越了几个缓冲区。然后通过中控数组进行缓冲区跳转,读写头重置的操作。给用户一种连续的错觉。

        语法糖:使用前置++去构造后置++,前置--去构造后置--(大家风范欸)

 三.优点

1.deque在扩容时,只拷贝中控数组指针且将元素拷贝至新的虚拟内存空间中断,头尾留冗余,相比vector开销更低。

2.相比vector可以在头尾两端高效插入。

3.相比List采用连续Buffer储存元素,页内碎片更少。

4.insert操作会判断插入位置与头尾两端的距离,选择较为近的位置移动元素,插入效率比vector高。

5.默认作为stack、queue适配器的底层容器。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值