使用“交换技巧”来修整容器过剩容量

假设你正在为TV游戏秀《Give Me Lots Of Money — Now!》写支持软件,而且你要跟踪可能的竞争者,你把它们保存在一个vector中:


class Contestant {...};

vector<Contestant> contestants;


当这个秀需要一个新的竞争者时,它将被申请者淹没,你的vector很快获得很多元素。但是秀的制作人只要预期的游戏者,一个相对少数符合条件的候选人移到vector前端(可能通过partial_sort或partition),如果不是候选人的就从vector删除(典型的通过调用erase的区间形式)。这很好地减少了vector的大小,但没有减少它的容量。如果你的vector有时候容纳了10万个的可能的候选人,它的容量会继续保持在至少100,000,即使后来它只容纳10个。


要避免你的vector持有它不再需要的内存,你需要有一种方法来把它从曾经最大的容量减少到它现在需要的容量。这样减少容量的方法常常被称为“收缩到合适(shrink to fit)”。收缩到合适很容易实现,但代码——我该怎么说?——比直觉的要少。让我演示给你看,然后我会解释它是怎么工作的。


这是你怎么修整你的竞争者vector过剩容量的方法:

vector<Contestant>(contestants).swap(contestants);


表达式vector<Contestant>(contestants)建立一个临时vector,它是contestants的一份拷贝:vector的拷贝构造函数做了这个工作。但是,vector的拷贝构造函数只分配拷贝的元素需要的内存,所以这个临时vector没有多余的容量。然后我们让临时vector和contestants交换数据,这时我们完成了,contestants只有临时变量的修整过的容量,而这个临时变量则持有了曾经在contestants中的发胀的容量。在这里(这个语句结尾),临时vector被销毁,因此释放了以前contestants使用的内存。瞧!收缩到合适。


同样的技巧可以应用于string:
string s;
...                             // 使s变大,然后删除所有条款17:使用“交换技巧”来修整过剩容量
                                // 它的字符
string(s).swap(s);      // 在s上进行“收缩到合适”


另外,交换技巧的变体可以用于清除容器和减少它的容量到你的实现提供的最小值。你可以简单地和一个默认构造的临时vector或string做个交换:
vector<Contestant> v;
string s;
...                                     // 使用v和s
vector<Contestant>().swap(v);          // 清除v而且最小化它的容量
string().swap(s);                               // 清除s而且最小化它的容量
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值