#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<int> v ;
v.resize(2);
v[0]=0;
v[1]=1;
cout<<"size=" <<v.size()<<" v[0]= "<<v[0]<<" v[1]= "<<v[1]<<" capacity= "<<v.capacity()<<"\n";
v.resize(1);
cout<<"size=" <<v.size()<<" v[0]= "<<v[0]<<" capacity= "<<v.capacity()<<"\n";
v.reserve(9);
cout<<"size=" <<v.size()<<" v[0]= "<<v[0]<<" capacity= "<<v.capacity()<<"\n";
v.resize(2);
cout<<"size=" <<v.size()<<" v[0]= "<<v[0]<<" v[1]= "<<v[1]<<" capacity= "<<v.capacity()<<"\n";
copy(v.begin(),v.end(),ostream_iterator<int>(cout,"\n"));
return 0;
}
输出结果:
size=2 v[0]= 0 v[1]= 1 capacity= 2
size=1 v[0]= 0 capacity= 2
size=1 v[0]= 0 capacity= 9
size=6 v[0]= 0 v[1]= 0 capacity= 9
0
0
2
3
4
5
size告诉你容器中目前实际有多少元素,而对应的,resize会在容器的尾部添加或删除一些元素来调整容器中实际的内容。
capacity会告诉你最少添加多少个元素才会导致容器重新分配内存。 而reserve在必要的时候会使容器的内部缓冲区扩充至一个更大的内存,但此时其扩充的部分仍然是空的!
operator[]()没有越界检查,如需要应该使用at() 。
运用copy这种方法,自动解决了迭代器!=、前缀++、end()、以及endl更新流等问题。