vector清空容器的操作以及个人的一些见解

当vector中存入大量的数据后,当我们不再使用vector中的元素后,如果能积极主动的去释放内存,那么是非常明智的。(对于小容量的数据,就没有这个必要了,因为对性能影响甚微)一、 知识背景:PS:这一部分是对文章题目所言操作的背景介绍,只关心题目的读者可以跳过为了支持随机访问,vector将元素连续存储到一块空间上(每个元素紧挨着前一个元素),那么当容器空间满了以后,再次插入新元素...
摘要由CSDN通过智能技术生成

当vector中存入大量的数据后,当我们不再使用vector中的元素后,如果能积极主动的去释放内存,那么是非常明智的。(对于小容量的数据,就没有这个必要了,因为对性能影响甚微)

一、 知识背景:

PS:这一部分是对文章题目所言操作的背景介绍,只关心题目的读者可以跳过

为了支持随机访问,vector将元素连续存储到一块空间上(每个元素紧挨着前一个元素),那么当容器空间满了以后,再次插入新元素的时候,容器必须分配新的内存空间来保存已有元素和新的元素,即将已有元素从旧位置挪到新位置,再添加新元素到新位置。如果当容器满了以后,每添加一个新元素,都要执行一次这样的操作,那么额外的开销未免太大了(拷贝旧元素)。
所以标准库为了减少这种额外的开销,通常在vector容量满了以后,再申请的空间通常是比以前的空间大很多的,不同的平台下具体实现不同(Linux下是2倍,Windows下Visual Stdio是1.5倍),这些额外的空间用来备用,可以用来保存更多的元素。这样,就不需要每次添加新元素都重新分配容器的内存空间了。

capacity() 方法就是返回vector在不重新分配空间的情况下,可以容纳元素的最大值,所以包含哪些也许还没有被使用的空间。而 size() 是返回vector中已保存/有效元素的个数。

二、清空容器并释放内存

第一种:
使用swap。swap的作用是交换两个容器底层的数据结构。如果我们创建一个临时的空vector和需要释放内存的vector交换底层数据结构,就相当于释放了内存。
demo:

#include <iostream>
#include <vector>

int main(){
   
	std::vector<int> ve;
	for (std::vector<int>::size_type i = 0; i < 100; ++i)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值