首先来看看vector的模板声明:

template <class T, class Alloc = allocator<T>>
class vector {
    //…
};

  vector接受2个模板参数,其中分配器属于默认参数,当然如果你想使用其他分配器话,得把2个参数都写出来,一般只需写入元素类型即可进行vector模板的实例化,如:

 vector<int> vec;

  vector属于序列式容器。所谓序列式容器,其中的元素都可序,但未必有序。vector与array其实挺像的, 唯一的区别就是array是静态空间,一旦配置了就不能改变。而vector呢,如果分配的空间不足,将会重新配置一块新空间,大小是原空间的2倍,然后将元素一一搬过来,最后释放旧空间。因此,vector比array更灵活。示意图如下:

(图片来自侯捷老师课程《STL与泛型编程》, 侵删)

(重新分配新空间 ,元素转移,释放旧内存)

  顺便提一下vector的迭代器:vector的迭代器其实就是普通指针,由于vector具有连续的地址空间,所以它的迭代器类型支持Random Access iterators,随机存取,可跳跃。由于它的迭代器特性,使得vector中元素如果要实现某些算法时效率极高,如二分搜索系列算法。

  vector常用的元素操作:push_back, pop_back, erase, insert, clear等。我们主要谈谈erase.

erase算法有两个版本:

iterator erase(iterator first, iterator last);     // 清除[first, last)中的所有元素
iterator erase(iterator position);                 // 清除某个位置上的元素

  附一段测试代码(版本为Dev C++5.11):

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int main()
{
    int i;
    vector<, );
    cout << "size = " << iv.size() << endl;                // size = 2
    cout << "capacity = " << iv.capacity() << endl;        // capacity = 2

    iv.push_back();
    cout << "size = " << iv.size() << endl;                // size = 3
    cout << "capacity = " << iv.capacity() << endl;        // capacity = 4

    iv.push_back();
    cout << "size = " << iv.size() << endl;                // size = 4
    cout << "capacity = " << iv.capacity() << endl;        // capacity = 4

    iv.push_back();
    cout << "size = " << iv.size() << endl;                // size = 5
    cout << "capacity = " << iv.capacity() << endl;        // capacity = 8

    iv.push_back();
    cout << "size = " << iv.size() << endl;                // size = 6
    cout << "capacity = " << iv.capacity() << endl;        // capacity = 8

    ; i < iv.size(); i++) {                      // 9  9  1  2  3  4
        cout << iv[i] << ' ';
    }
    cout << endl;

    iv.push_back();
    cout << "size = " << iv.size() << endl;                // size = 7
    cout << "capacity = " << iv.capacity() << endl;        // capacity = 8   

    ; i < iv.size(); i++) {                      // 9  9  1  2  3  4  5
        cout << iv[i] << ' ';
    }
    cout << endl;

    vector<);
    if (ivite != iv.end()){
        iv.erase(ivite);
    }

    cout << "size = " << iv.size() << endl;                // size = 6
    cout << "capacity = " << iv.capacity() << endl;        // capacity = 8

    ; i < iv.size(); i++) {                      // 9  1  2  3  4  5
        cout << iv[i] << ' ';
    }
    cout << endl;

    ivite = find(iv.begin(), iv.end(), );
    if (ivite != iv.end()){
        iv.insert(ivite, 1, );                            // insert算法内部实现比较复杂(不做详谈)如:当备用空间不足,配置新内存的长度
    }                                                      // 旧长度的2倍,或是旧长度+新增元素个数

    cout << "size = " << iv.size() << endl;                // size = 7
    cout << "capacity = " << iv.capacity() << endl;        // capacity = 8

    ; i < iv.size(); i++) {
        cout << iv[i] << ' ';                              // 9  1  7  2  3  4  5
    }
    cout << endl;

    iv.clear();
    cout << "size = " << iv.size() << endl;                // size = 0
    cout << "capacity = " << iv.capacity() << endl;        // capacitu = 8

  return 0;
}

STL之序列容器vector的更多相关文章

  1. C++线性序列容器<vector>简单总结

    C++线性序列容器<vector>简单总结 vector是一个长度可变的数组,使用的时候无须声明上限,随着元素的增加,Vector的长度会自动增加:Vector类提供额外的方法来增加.删除 ...

  2. STL常用序列容器

    这里简要的记述一下STL常用容器的实现原理,要点等内容. vector vector是比较常用的stl容器,用法与数组是非类似,其内部实现是连续空间分配,与数组的不同之处在于可弹性增加空间,而arra ...

  3. STL标准库-容器-vector

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性. 向量容器vector是一个动态数组,内存连续,它是动态分配内存,且每次扩张的原来的二倍. 他的结构如下 一 定义 vector ...

  4. STL之序列容器deque

    首先看看deque的模板声明: template <class T,  class Alloc = allocator<T>>  // 原本还有个参数BufSize,现在新版本 ...

  5. C++STL(二)——vector容器

    STL--vector容器 vector对象的概念 vector基本操作 vector对象的初始化.赋值 vector查找.替换(已在上一片 string类 博客总结过了,不再总结) vector添加 ...

  6. C++中防止STL中迭代器失效——map/set等关联容器——vector/list/deque等序列容器—如何防止迭代器失效—即erase()的使用

    序列性容器::(vector和list和deque)   erase迭代器不仅使所有指向被删元素的迭代器失效,而且使被   删元素之后的所有迭代器失效,所以不能使用erase(iter++)的方 式, ...

  7. C++进阶 STL(1) 第一天 [容器,算法,迭代器] string容器 vector容器 deque容器

    课程大纲 02实现基本原理 容器,算法,迭代器 教室:容器 人:元素 教室对于楼:容器 序列式容器: 容器元素在容器中的位置是由进入容器的时间和地点来决定 序列式容器 关联式容器: 教室中 按年龄排座 ...

  8. 《STL源码剖析》——第四章、序列容器

     1.容器的概观与分类 所谓序列式容器,其中的元素都可序(ordered)[比如可以使用sort进行排序],但未必有序(sorted).C++语言本身提供了一个序列式容器array,STL另外再提供v ...

  9. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

随机推荐

  1. Myeclipse添加外部Tomcat出现启动故障的问题解决

    故障: 1.java.lang.IllegalStateException: No output folder 分析:work文件夹无写权限 解决:找到tomcat的安装文件夹,右键点击work文件夹 ...

  2. Codeforces Round #341 Div.2 C. Wet Shark and Flowers

    题意: 不概括了..太长了.. 额第一次做这种问题 算是概率dp吗? 保存前缀项中第一个和最后一个的概率 然后每添加新的一项 就解除前缀和第一项和最后一项的关系 并添加新的一项和保存的两项的关系 这里 ...

  3. Python3 之 import 和 当前目录

    环境: Python-3.4.3 Web.py-0.37 安装 web.py 的时候,提示 ImportError: No module named 'utils' 看看源码,setup.py,有这么 ...

  4. 使用dispatch_semaphore_t实现event的基本功能

    在Windows平台下, 对线程的同步控制,可以有Critical Section,Mutex,Semaphore,Event 等方式. 在IOS平台,使用GCD进行简单的多线程编程时,可以使用dis ...

  5. [课程设计]Scrum 1.2 Spring 计划&系统流程&DayOne燃尽图

    多鱼点餐系统WEB Spring 计划 ● 产品BACKLOG 多鱼点餐系统产品BACKLOG ID Name Imp Est How to demo Notes 1 设计框架结构 10 8 利用美学 ...

  6. DotNet 资源大全中文版【转】

    转自:https://github.com/jobbole/awesome-dotnet-cn 我想很多程序员应该记得 GitHub 上有一个 Awesome - XXX 系列的资源整理.awesom ...

  7. 【linux】linux shell 日期格式化

      获得当天的日期 date +%Y-%m-%d 输出: 2011-07-28 将当前日期赋值给DATE变量DATE=$(date +%Y%m%d) 有时候我们需要使用今天之前或者往后的日期,这时可以 ...

  8. c#变量缺少using引用,如何快速加上using,加Using的快捷键[bubuko.com]

    在vs的“工具”->“选项”中,左侧树形菜单,“环境”下的“键盘”中设置快捷键. 在“显示命令包含”输入框内输入“显示智能标记”,找到“视图.显示智能标记”,可以看到该命令的快捷键已经分配了2个 ...

  9. Flexigrid从对象中加载数据

    (有问题,在找…………) Flexigrid是用来动态加载数据的一种比较好(老)的Jquery表插件,然后有些时候,我们需要其从本地或者jQuery对象中加载数据,比如有这么个需求,页面显示中有两个表 ...

  10. LeetCode "Design Twitter"

    A mix of hashmap, list and heap. struct Tw { Tw(long long pts, int tid) { ts = pts; tweetid = tid; } ...