STL中vector是通常作为数组使用,不过它更像一个动态数组,在实际项目开发中大量使用.
优点:存储空间连续,可以使用下标访问,时间复杂度O(1).
缺点:不适合从中间删除和添加元素.
C++标准规定的vector模板声明:

template < class T, class Allocator = allocator<T> > class vector;

T : 存储的数据类型
Allocator : 存储空间分配器(默认为std::allocator<T>)

1)首先vector可以作为数组使用,因此我们可以在初始化vector时,指定元素个数和初始值.
vector<int> v;        //v中含有0个元素
vector<int> v(5);     //v中含有5个元素
vector<int> v(5, 1);  //v中含有5个元素,赋予初始值1

另外vector还可以通过其他方式构造:
vector<int> third (v.begin(),v.end());  //通过v构造third
vector<int> fourth (third); //通过copy构造

//通过数组进行初始化
int myints[] = {16,2,77,29};
vector<int> fifth (myints, myints + sizeof(myints) / sizeof(int) );
这里暂且介绍这几种,更多构造方式查看C++手册.

2)其次我们要介绍下vector对内存的管理.
vector成员函数: size_type size() const;返回当前容器中元素个数
                size_type capacity() const;返回当前容量大小(并不一定等于size())
vector为了减少内存频繁申请和释放capacity()返回的是当前容器实际申请内存空间所能容纳的元素个数,当我们在容器添加元素个数大于capacity()的大小时,容器将通过内存分配器重新分配空间(注: 一旦size()中的元素被移除掉, 被移除的对象对应的析构函数将会被调用.).
下面我们通过例子具体看看:
程序1:
    vector<int> v;
    for (size_t i = 0; i < 100; ++ i)
        v.push_back(i);

cout << v.size() << endl;
    cout << v.capacity() << endl;
输出:
100
141
可以看到size() 和 capacity()大小不一致.在vs中我们追踪push_back函数可以看到

首先比较size()和capacity()大小,如果容器容量足够容纳元素则直接添加至尾部,否则我们进入insert函数继续追踪,
进入_Insert_n中,我们看到一旦新添加元素数量和当前实际使用元素数量大于capacity()后,则容器容量尝试以50%的容量增长.
 
vector的成员函数: void resize ( size_type sz, T c = T() );改变实际元素个数.
1.如果_Newsize小于size(),则容器将截断后面(size() - _Newsize)个元素, 保留前面的元素;
2.如果_Newsize大于size(),则容器将调用_Insert_n函数进行插入操作,只有(_Newsize - size())的元素才使用初始化值进行初始化,原来的size()个元素保持不变.
 
vector成员函数: void reserve ( size_type n );改变容器容量大小.
1.如果n小于capacity()大小,则容器并不会进行释放内存重新分配,此操作无效.
2.如果n大于capacity()大小,则容器重新分配内存,并将原来元素copy进新的内存中.
程序2:
     vector<int > v;
    for (size_t i = 0; i < 100; ++ i )
        v.push_back (i);
 
    v.reserve (10);
 
    cout << v .size() << endl;
    cout << v .capacity() << endl;
输出:
100
141
 
程序3:
     vector<int > v;
    for (size_t i = 0; i < 100; ++ i )
        v.push_back (i);
 
    v.reserve (150);
 
    cout << v .size() << endl;
    cout << v .capacity() << endl;
输出:
100
150
 
vector的clear()操作并不会造成内存的释放,只是改变实际元素个数置为0;而iterator erase ( iterator position );操作也只是对元素进行移动操作,并不会释放内存.
 
总结:我们在使用vector时最好事先分配一定的数量的元素空间,删除和添加最好在尾部操作. 

STL总结之vector的更多相关文章

  1. 转:用STL中的vector动态开辟二维数组

    用STL中的vector动态开辟二维数组 源代码:#include <iostream>#include <vector>using namespace std;int mai ...

  2. STL中的Vector相关用法

    STL中的Vector相关用法 标准库vector类型使用需要的头文件:#include <vector>. vector 是一个类模板,不是一种数据类型,vector<int> ...

  3. (转)C++ STL中的vector的内存分配与释放

    C++ STL中的vector的内存分配与释放http://www.cnblogs.com/biyeymyhjob/archive/2012/09/12/2674004.html 1.vector的内 ...

  4. C++STL中的vector的简单实用

    [原创] 使用C++STL中的vector, #include <stdio.h> #include<stdlib.h> #include<vector> usin ...

  5. STL中的vector实现邻接表

    /* STL中的vector实现邻接表 2014-4-2 08:28:45 */ #include <iostream> #include <vector> #include  ...

  6. C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法

    每次忘记都去查,真难啊 /* C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法 */ /* vector常用用法 */ //头文件 #i ...

  7. [转] C++的STL库,vector sort排序时间复杂度 及常见容器比较

    http://www.169it.com/article/3215620760.html http://www.cnblogs.com/sharpfeng/archive/2012/09/18/269 ...

  8. Linux环境下stl库使用(vector)

    step1: #include <iostream> #include <vector> #include <string> using namespace std ...

  9. stl 中List vector deque区别

    stl提供了三个最基本的容器:vector,list,deque.         vector和built-in数组类似,它拥有一段连续的内存空间,并且起始地址不变,因此     它能非常好的支持随 ...

随机推荐

  1. android的liveview装载数据

    设置布局 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:andro ...

  2. hdu 2844 poj 1742 Coins

    hdu 2844 poj 1742 Coins 题目相同,但是时限不同,原本上面的多重背包我初始化为0,f[0] = 1;用位或进行优化,f[i]=1表示可以兑成i,0表示不能. 在poj上运行时间正 ...

  3. NSAssert使用摘抄

    #define NSAssert(condition, desc, ...) 只有条件condition满足,才会执行下一个语句,否则输出断言错误. 例如: NSAssert(1 != 2, @&qu ...

  4. Microsoft Visual Studio 2010 Service Pack 1(exe)

    在线安装包:https://cid-3ca83445bd7767a0.office.live.com/browse.aspx/.Public/VS2010 ISO:http://download.mi ...

  5. webkit私有css3属性 -webkit-overflow-scrolling:touch;

    -webkit-overflow-scrolling:touch;/*允许独立的滚动区域和触摸回弹*/ 这个属性可以提高滚动的平滑度

  6. sizeof()和strlen()在求字符串长度时的差别

    sizeof()函数输出字符串长度时会把结束符计算在内: strlen()函数输出字符串长度时不会把结束符计算在内. 如图:

  7. Spring中argNames的含义

    最近学习Spring,一直不太明白Srping的切面编程中的的argNames的含义,经过学习研究后,终于明白,分享一下 先看一个例子: 需要监控的类: package bean; public cl ...

  8. Python中zip()函数用法

    定义:zip([iterable, …])zip()是Python的一个内建函数,它接受一系列可迭代的对象作为参数,将对象中对应的元素打包成一个个tuple(元组),然后返回由这些tuples组成的l ...

  9. 上次的AJAX定时刷新多ID不正确,这次请教了高手之后补全

    关键是setInterval无法传递参数,所以用了匿名函数再包裹一下就好了. //重置发布进度 function resetPercent(id_data){ $.ajax({ url:'/autod ...

  10. linux-0.11内核 任务的堆栈切换

    http://blog.163.com/di_yang@yeah/blog/static/86118492201212534924900/ 一直缠绕的两个问题:怎样标识的内核栈与用户栈?如何在内核态堆 ...