[以下内容出自<effective stl>]
要避免你的vector持有它不再需要的内存,你需要有一种方法来把它从曾经最大的容量减少到它现在需要的
容量。这样减少容量的方法常常被称为“收缩到合适(shrink to fit)”。
收缩到合适很容易实现,但代码——我该怎么说?——比直觉的要少。让我演示给你看,然后我会解释它是怎么工作的。
这是你怎么修整你的竞争者vector过剩容量的方法:
vector<Contestant>(contestants).swap(contestants);
表达式vector<Contestant>(contestants)建立一个临时vector,它是contestants的一份拷贝:vector的拷贝构造函数
做了这个工作。但是,vector的拷贝构造函数只分配拷贝的元素需要的内存,所以这个临时vector没有多余的
容量。然后我们让临时vector和contestants交换数据,这时我们完成了,contestants只有临时变量的修整过的容
量,而这个临时变量则持有了曾经在contestants中的发胀的容量。在这里(这个语句结尾),临时vector被销
毁,因此释放了以前contestants使用的内存。瞧!收缩到合适。