C++ Vector用法深入剖析
C++ Vector用法深入剖析
http://blog.csdn.net/u012062327
C++编程语言中有一种叫做Vector的应用方法,它的作用在实际编程中是非常重要的。在这里我们将会为大家详细介绍一下C++ Vector的相关应用技巧及基本内容,希望能给大家带来一些帮助。
vector是STL中最常见的容器,它是一种顺序容器,支持随机访问。vector是一块连续分配的内存,从数据安排的角度来讲,和数组极其相似,不同的地方就是:数组是静态分配空间,一旦分配了空间的大小,就不可再改变了;而vector是动态分配空间,随着元素的不断插入,它会按照自身的一套机制不断扩充自身的容量。
vector的扩充机制:按照容器现在容量的一倍进行增长。vector容器分配的是一块连续的内存空间,每次容器的增长,并不是在原有连续的内存空间后再进行简单的叠加,而是重新申请一块更大的新内存,并把现有容器中的元素逐个复制过去,然后销毁旧的内存。这时原有指向旧内存空间的迭代器已经失效,所以当操作容器时,迭代器要及时更新。
vector数据结构,采用的是连续的线性空间,属于线性存储。他采用3个迭代器_First、_Last、_End来指向分配来的线性空间的不同范围,下面是声明3个迭代器变量的源代码。
template<class _Ty, class _A= allocator< _Ty> >
class vector{
...
protected:
iterator _First, _Last, _End;
};
_First指向使用空间的头部,_Last指向使用空间大小(size)的尾部,_End指向使用空间容量(capacity)的尾部。例如:
int data[6]={3,5,7,9,2,4};
vector<int> vdata(data, data+6);
vdata.push_back(6);
...
vector初始化时,申请的空间大小为6,存放下了data中的6个元素。当向vdata中插入第7个元素“6”时,vector利用自己的扩充机制重新申请空间,数据存放结构如图1所示:
图1 扩充后的vector内存结构
简单描述一下。当插入第7个元素“6”时,vector发现自己的空间不够了,于是申请新的大小为12的内存空间(自增一倍),并将前面已有数据复制到新空间的前部,然后插入第7个元素。此时_Last迭代器指向最后一个有效元素,而_End迭代器指向vector的最后有效空间位置。我们利用vector的成员函数size可以获得当前vector的大小,此时为7;利用capacity成员函数获取当前vector的容量,此时为12。
(1)vector< 类型 > 标识符 ;
(2)vector< 类型 > 标识符(最大容量) ;
(3)vector< 类型 > 标识符(最大容量,初始所有值);
(4) int i[4] = {12,3,4,5};
- vector< 类型 > vi(i , i+2); //得到i索引值为3以后的值 ;
(5)vector< vector<int> > //vi 定义2维的容器;记得一定要有空格,不然会报错
- vector< int > line
- // 在使用的时候一定要首先将vi个行进行初始化;
- for(int i = 0 ; i < 10 ; i ++)
- {
- vector.push_back(line);
- }
- /// 个人认为使用vector定义二维数组很好,
因为是长度可以不预先确定。很好。
(6)C++ Vector排序
- vector< int > vi ;
- vi.push_back(1);
- vi.push_back(3);
- vi.push_back(0);
- sort(vi.begin() , vi.end()); /// /小到大
- reverse(vi.begin(),vi.end()) /// 从大道小
(7)顺序访问
- vector < int > vi ;
- for( int i = 0 ; i < 10 ; i ++)
- {
- vector.push_back(i);
- }
- for(int i = 0 ; i < 10 ; i ++) /// 第一种调用方法
- {
- cout <<vector[i] <<" " ;
- }
- for(vector<int>::iterator it = vi.begin() ;
- it !=vi.end() ; it++) ///第二种调用方法
- {
- cout << *it << " " ;
- }
(8)寻找
- vector < int > vi ;
- for( int i = 0 ; i < 10 ; i ++)
- {
- vector.push_back(i);
- }
- vector < int >::interator it = find(vi.begin() , vi.end,3) ;
- cout << *it << endl ; ///返回容器内找到值的位置。
(9)使用数组对C++ Vector进行初始化
- int i[10] ={1,2,3,4,5,6,7,78,8} ;
- ///第一种
- vector<int> vi(i+1,i+3); ///从第2个元素到第三个元素
- for(vector <int>::interator it = vi.begin() ;
- it != vi.end() ; it++)
- {
- cout << *it <<" " ;
- }
(10) 结构体类型
- struct temp
- {
- public :
- string str ;
- public :
- int id ;
- }tmp
- int main()
- {
- vector <temp> t ;
- temp w1 ;
- w1.str = "Hellowor" ;
- w1.id = 1 ;
- t.push_back(t1);
- cout << w1.str << "," <<w1.id <<endl ;
- return 0 ;
- }
c.clear() 移除容器中所有数据。 c.erase(pos)// 删除pos位置的数据,传回下一个数据的位置。 c.erase(beg,end) 删除[beg,end)区间的数据,传回下一个数据的位置。