vector<int> vec(2);
cout<<vec.size()<<endl;//2
vec.resize(5);
cout<<vec.size()<<endl;//5
vec.push_back(5);
vec.push_back(6);
cout<<vec.size()<<endl;//7
vector< pair<double, pair<int,int> > > vecPair;
pair<int, int> in = make_pair(10,20);
vecPair.push_back(make_pair(12.1, in));
vecPair.push_back(make_pair(11.1, make_pair(1, 2)));
vecPair.push_back(make_pair(13.1, make_pair(1, 2)));
vecPair.push_back(make_pair(11.1, make_pair(2, 2)));
vecPair.push_back(make_pair(11.1, make_pair(0, 2)));
sort(vecPair.begin(), vecPair.end()); //支持排序
for(int z=0; z<vecPair.size(); z++)
{
cout<<vecPair[z].first<<" "<<vecPair[z].second.first<<" "<<vecPair[z].second.second<<endl;
}
vector<int> vecInt;
cout<<(int)vecInt.size()-1<<endl;//无符号减有符号,向无符号升级
针对vector做一些删除操作后,capacity大小不会自动变小的,如果后续不再由插入数据的新动作,那么capacity(<size)分配的闲置内存就比较浪费了,可以通过调用swap函数进行shrink 2 fit (瘦身或者减肥)。vector<string>(vec).swap(vec); ------so, 扩展下 应该也可以使用相同的方法删除元素and fit capacity to zero
同样的string类也可以使用swap进行如上操作:
string strMyStr;
strMyStr = "fengdijiang";
{
string(strMyStr).swap(strMyStr);
}
需要注意的是swap后,迭代器、引用、指针都会交换,但是但是string是个例外