vector利用swap()函数进行内存的释放
首先,vector与deque不同,其内存占用空间只会增长,不会减小。比如你首先分配了10,000个字节,然后erase掉后面9,999个,则虽然有效元素只有一个,但是内存占用仍为10,000个。所有空间在vector析构时回收。
1、释放内存:
empty()是用来检测容器是否为空的,clear()可以清空所有元素。但是即使clear(),所占用的内存空间依然如故。如果你需要空间动态缩小,可以考虑使用deque。如果非要用vector,这里有一个办法:
在《effective STL》和其实很多C++文章中都有指明,用clear()无法保证内存回收。但是swap技法可以。具体方法如下所示:
vector<int> ivec;
ivec.push_back(1);ivec.push_back(1);ivec.push_back(2);ivec.push_back(2);
vector<int>().swap(ivec); //或者ivec.swap(vector<int>());
vector<int>().swap(ivec); 或者如下所示 加一对大括号都可以,意思一样的:
{
std::vector<int> tmp;
ivec.swap(tmp);
}
加一对大括号是可以让tmp退出{}的时候自动析构
2、修整空间
在一个应用中,可能会需要向一个vector中插入很多记录,比如说100000条,为了避免在插入过程中移动内存,咱实现向系统预订一段足够的连续的空间,例如
vector<int> ivec;
ivec.reserve(100000);
这个问题是解决了。
但是,如果后来这个vector不再需要存那么多的元素了,已经通过erase删除了。但是以前咱们预留的空间却无法被其他程序再度利用,这样会造成内存一定程度上的浪费。于是,我们利用目前的vector构造一个一模一样的vector,他并没有预留空间,于是以前预留的空间也被释放以作他用了:
ivec.swap(vector<int>(ivec)); // or vector<int>(ivec).swap(ivec)
或者如下所示 加一对大括号都可以,意思一样的:
{
std::vector<int> tmp = ivec;
ivec.swap(tmp);
}
加一对大括号是可以让tmp退出{}的时候自动析构
使用这种方法的前提是vector从前存储了大量数据,比如10000000,经过各种处理后,现在只有100条,那么向清空原来数据所占有的空间,就可以通过这种交换技术swap技法就是通过交换函数swap(),使得vector离开其自身的作用域,从而强制释放vector所占的内存空间。
#include "stdafx.h"
#include <vector>
#include <iostream>
using namespace std;
int main(int argc, char* argv[])
{
vector <int> v1, v2;
cout << "The number of elements in v1 = " << v1.size( ) << endl;
cout << "The number of elements in v2 = " << v2.size( ) << endl;
cout << v1.capacity() << endl;
cout << v2.capacity() << endl;
v1.push_back( 1 );
v1.push_back( 2 );
v1.push_back( 3 );
v2.push_back( 10 );
v2.push_back( 20 );
cout << "The number of elements in v1 = " << v1.size( ) << endl;
cout << "The number of elements in v2 = " << v2.size( ) << endl;
cout << v1.capacity() << endl;
cout << v2.capacity() << endl;
cout << endl;
v1.swap( v2 );
cout << "The number of elements in v1 = " << v1.size( ) << endl;
cout << "The number of elements in v2 = " << v2.size( ) << endl;
cout << v1.capacity() << endl;
cout << v2.capacity() << endl;
return 0;
}
vector利用swap()函数进行内存的释放相关推荐
- C语言中利用Swap函数交换变量a,b
C语言中利用Swap函数交换变量a,b 常见错误写法 error1 void Sawp_error1(int a,int b) {int tmp;tmp=a;a=b;b=tmp; } int main ...
- c语言的free函数与内存空间释放
目录 0 缘起 1 free() 使用前 - free前程序做了什么 2 free 的作用 - free对内存做了什么 - free对指针做了什么 3 free后怎样做 4 Q&A (1) Q ...
- 利用swap函数的三种写法
简述: 本节记录一下两个数据进行交换的三种写法. 其中第三中可算有点趣味. A.手写swap 利用我们自己写的swap函数,利用引用来交换. #include<iostream> usin ...
- java swap函数_Java 利用swap函数交换两个整型数据值
提到交换两个数a, b的值,一定可以想起很多方法,a = a+b;b = a - b; a = a - b;借助temp的方法等等,但是如果食用swap方法的话,这个问题可是很有研究的了,要求使用sw ...
- C++STL中swap函数操作与内存地址改变的简析
写在前面 这篇文章主要讨论了STL中swap函数在交换2个容器的内容的时候是交换内存还是交换元素的问题.由于博主对C++的学习并不好,如果有什么错误恳请大家提出.下面会有一些代码展示一下swap函数在 ...
- 【转】 谈谈C++中的swap函数
1,最通用的模板交换函数模式:创建临时对象,调用对象的赋值操作符. 1 template <class T> void swap ( T& a, T& b ) 2 { 3 ...
- 谈谈C++中的swap函数
1,最通用的模板交换函数模式:创建临时对象,调用对象的赋值操作符. template <class T> void swap ( T& a, T& b ) {T c(a); ...
- Vector的所有函数
构造函数 语法: C++ Vectors可以使用以下任意一种参数方式构造: vector(); //无参数 - 构造一个空的vector vector( size_type num, const ...
- stl swap函数_C ++ STL | vector :: swap()函数与示例
stl swap函数 C ++ STL vector :: swap()函数 (C++ STL vector::swap() function) vector::swap() function is ...
最新文章
- 收款神器!解读聚合收款码背后的原理|原创
- SSL WS-Security--Web Service安全保障
- 相关与卷积(数字信号处理)的数学原理及 Python 实现
- Eclipse 引导阮卓项目 No projects are found to import解
- 一篇文章带初学者明白:什么是编译器,什么是集成开发环境(IDE)?
- 深入浅出 Java 8 Lambda 表达式
- python模型训练框架_以Python撰写 AI模型框架
- fckeditor代码总结
- 安装cad提示command_win7系统安装CAD软件失败总是提示“错误1327”怎么解决
- find命令的基础用法以及按文件修改时间查找文件
- 下着雨的星期天下午,年素清一个人走在外面
- 浅谈javascript面向对象理解
- 企业小程序应该如何开发?
- 容器云系列之Kubernetes基本架构介绍
- 【C语言】程序结构、基本语法、数据类型
- 微电影制作迅速走红的原因
- 写一个自我简介,列出对软件工程课程的希望及个人目标
- K-means均值聚类算法python代码实现
- 哪个封面更像锦绣蓝图?
- 机器学习第一练(铁达尼号罹难者预测)
热门文章
- clion 查看内容窗口_苹果电脑(macOS)查看 WiFi 密码的两种方法
- 在只需要一个指定正确的参数的情况下如何防止传入其他干扰的参数
- kubernetes mysql pxc_K8S使用operator部署和管理Percona - PXC集群
- Lock锁实现多线程卖票
- 我的世界服务器显示不出地图,为什么我的世界服务器地图加载不了
- emlog链接html,emlog如何做站内外链跳转优化教程
- CSS基础选择器(选择器的优先级),CSS样式块( 长度/颜色/显示方式/文本样式),盒模型组成,盒模型-block,盒模型布局...
- linix防火墙设置之顺序设置问题 -- 解决防火墙规则顺序和插入规则到指定序号的问题...
- getDate()返回日期不一致问题引发的bug
- 面试题12:打印1到最大的n位数