vector析构时,vector和string申请的内存都会被正确释放,不会引发内存泄漏。但这些内存不一定会被返还给操作系统。即这一部分内存已经可用,但依然被进程持有,参见。注:std::vector<:string>().swap(x)在释放内存上的效果和直接析构x没有区别,它依赖于vector的析构来完成内存释放。这种方案可以安全的清空x,并释放其持有的内存,随后x依然可用。
如果你在vector被析构前观察到大量内存未被释放,那么可能是vector额外持有内存导致的(调用vector::capacity可检查vector持有多少内存)。vector的内存管理机制会导致这一现象——vector可能不会在移除元素后释放内存,vector可能会申请多一倍的内存——这是为了降低添加/移除元素时的拷贝开销。
在需要释放vector持有的额外内存时,标准做法是调用 vector::shrink_to_fit 。考虑到shrink_to_fit是实现相关的,也可以自己编写一个:
std::vector<:string> a(100, "abc");
a.erase(a.begin(), a.begin() + 10);
{ // shrink to fit
std::vector<:string> b;
b.reserve(a.size());
std::move(a.begin(), a.end(), std::back_inserter(b));
a = std::move(b);
}
{ // another workaround
a = std::vector<:string>(std::make_move_iterator(a.begin()), std::make_move_iterator(a.end()));
}