美文网首页
11. C++ deque

11. C++ deque

作者: 郑行_aover | 来源:发表于2019-05-22 18:17 被阅读0次


    1. deque 介绍

    是一种优化了的、对序列两端元素进行添加和删除操作的基本序列容器。它允许较为快速地随机访问,但它不像vector 把所有的对象保存在一块连续的内存块,而是采用多个连续的存储块,并且在一个映射结构中保存对这些块及其顺序的跟踪。向deque 两端添加或删除元素的开销很小。它不需要重新分配空间,所以向末端增加元素比vector 更有效。

    实际上,deque 是对vector 和list 优缺点的结合,它是处于两者之间的一种容器。

    其实说到deque的多个连续分配的内存块这儿,我们来看看一个例子

    int main(){
          deque<int>deq(1,1);
          cout<<deq.max_size()<<endl;
          for(int i =0;i<deq.size();i++){
               cout<<deq[i]<<","<<&deq[i]<<endl;
        }
        
        cout<<"=========================="<<endl;
        int a=1;
        deq.push_back(12);
        deq.push_back(12);
        deq.push_back(12);
        for(i =0;i<deq.size();i++){
           cout<<deq[i]<<","<<&deq[i]<<endl;
        }
        cout<<"=========================="<<endl;
        int  b=1;
        deq.push_back(12);
        deq.push_back(12);
        deq.push_back(12);
        for(i =0;i<deq.size();i++){
           cout<<deq[i]<<","<<&deq[i]<<endl;
        }
        cout<<"=========================="<<endl;
        int c=1;
        deq.push_back(12);
        deq.push_back(12);
        deq.push_back(12);
        for(i =0;i<deq.size();i++){
           cout<<deq[i]<<","<<&deq[i]<<endl;
        }
    }
    

    我们发现原来一直以来它不像vector那样每次都会重新分配一段内存,然后拷贝,销毁原来的旧的内存,其实他也是预分配好大的连续内存块,如果不够了,然后会有另外一块大的连续内存块等着你使用。

    2. deque的特点

    (1) 随机访问方便,即支持[ ] 操作符和deque.at() ,但性能没有vector 好;?????支持[ ]访问?

    (2) 可以在内部进行插入和删除操作,但性能不及list ;

    (3) 可以在两端进行push 、pop ;

    (4) 相对于verctor 占用更多的内存。

    双向队列和向量很相似,但是它允许在容器头部快速插入和删除(就像在尾部一样)。

    3. deque的函数

    1.Constructors 创建一个新双向队列
    语法:

    deque();//创建一个空双向队列
    deque( size_type size );// 创建一个大小为size的双向队列
    deque( size_type num, const TYPE &val ); //放置num个val的拷贝到队列中
    deque( const deque &from );// 从from创建一个内容一样的双向队列
    deque( input_iterator start, input_iterator end );
    // start 和 end - 创建一个队列,保存从start到end的元素。
    

    2.Operators 比较和赋值双向队列

    //可以使用[]操作符访问双向队列中单个的元素

    3.assign() 设置双向队列的值

    语法:

    void assign( input_iterator start, input_iterator end);
    //start和end指示的范围为双向队列赋值
    void assign( Size num, const TYPE &val );//设置成num个val。
    

    4.at() 返回指定的元素

    语法:

    reference at( size_type pos ); 返回一个引用,指向双向队列中位置pos上的元素
    

    5.back() 返回最后一个元素

    语法:

    reference back();//返回一个引用,指向双向队列中最后一个元素
    

    6.begin() 返回指向第一个元素的迭代器

    语法:

    iterator begin();//返回一个迭代器,指向双向队列的第一个元素
    

    7.clear() 删除所有元素

    8.empty() 返回真如果双向队列为空

    9.end() 返回指向尾部的迭代器

    10.erase() 删除一个元素

    语法:

    iterator erase( iterator pos ); //删除pos位置上的元素
    
    iterator erase( iterator start, iterator end ); //删除start和end之间的所有元素
    

    //返回指向被删除元素的后一个元素

    11.front() 返回第一个元素的引用 8

    12.get_allocator() 返回双向队列的配置器

    13.insert() 插入一个元素到双向队列中

    语法:

    iterator insert( iterator pos, size_type num, const TYPE &val ); //pos前插入num个val值
    
    void insert( iterator pos, input_iterator start, input_iterator end );
    
    //插入从start到end范围内的元素到pos前面
    

    14.max_size() 返回双向队列能容纳的最大元素个数

    15.pop_back() 删除尾部的元素

    16.pop_front() 删除头部的元素

    17.push_back() 在尾部加入一个元素

    18.push_front() 在头部加入一个元素

    19.rbegin() 返回指向尾部的逆向迭代器

    20.rend() 返回指向头部的逆向迭代器

    21.resize() 改变双向队列的大小

    22.size() 返回双向队列中元素的个数

    23.swap() 和另一个双向队列交换元素

    语法:

    void swap( deque &target );// 交换target和现双向队列中元素
    

    4. 总结

    • vector 是一段连续的内存块,而deque 是多个连续的内存块, list 是所有数据元素分开保存,可以是任何两个元素没有连续。

    • vector 的查询性能最好,并且在末端增加数据也很好,除非它重新申请内存段;适合高效地随机存储,当然他有capacity这样的方法来获得他的容量。

    • list 是一个链表,任何一个元素都可以是不连续的,但它都有两个指向上一元素和下一元素的指针。所以它对插入、删除元素性能是最好的,而查询性能非常差;适合大量地插入和删除操作而不关心随机存取的需求。

    • deque 是介于两者之间,它兼顾了数组和链表的优点,它是分块的链表和多个数组的联合。所以它有比list好的查询性能,有比vector好的插入、删除性能。 如果你需要随机存取又关心两端数据的插入和删除,那么deque是最佳之选。

    还是那句话,deque为了实现整体连续的假象,导致其实现起来比较繁琐,尽量少使用它。另外,如果需要对deque进行排序的话,最好是先复制到vector中,然后再进行排序,最后在把元素拷贝回来,这样效率会提高一点。

    相关文章

      网友评论

          本文标题:11. C++ deque

          本文链接:https://www.haomeiwen.com/subject/uttpzqtx.html