虽然stl容器可以动态分配空间,尤其是顺序容器。但是很多情况下,为了避免对内存的多次分配,将会预先给容器分配很大的内存空间,等数据分配完成后,再进行去除多余的空间,这种方式可以有效提供程序的效率。
这里采用下面的做法,可以从容器中去除多余的向量:
vector<Constestant>(constestants).swap(constestants);
代码如下:
#include<iostream>
#include<vector>
using namespace std;
int main() {
vector<int>v;
v.reserve(10000);
for (int i = 1; i < 10; i++)
v.push_back(i);
vector<int>(v).swap(v);
return 0;
}
上述代码实现的功能为:预先对vector容器分配10000*sizeof(int)大小的空间,待实际分配结束时,通过swap函数进行释放,使得reserve与size的大小保持一致。