我试图了解有关C中如何处理内存的更多信息,并且我有一个关于重新分配变量时如何释放内存的问题.为了监视内存消耗,我有一个(特定于Linux的)函数CheckMem(),该函数调用pmap以查看该进程正在使用多少内存.
然后,我简单地创建一个大小为1的向量,将其重新分配为大小为一百万的向量,然后再次将其重新分配为大小为1,并观察内存如何变化.
#include <iostream>
#include <vector>
#include <sstream>
#include <cstdio>
#include <unistd.h>
using namespace std;
void CheckMem()
{
char cmdstring[100],outbuf[500],buf[100];
sprintf(cmdstring,"pmap -x %d | tail -1",getpid());
FILE* output = popen(cmdstring,"r");
fgets(outbuf,500,output);
size_t kb,rss,dirty;
istringstream ss(outbuf);
ss >> cmdstring >> buf >> kb >> rss >> dirty;
cout << "RSS: " << rss << " KB" << endl;
}
int main()
{
vector<double> vd(1);
CheckMem();
vd = vector<double>(1000000);
CheckMem();
vd = vector<double>(1);
CheckMem();
return 0;
}
如果使用g(gcc版本4.8.4)进行编译,则会得到以下输出:
RSS: 1184 KB
RSS: 9128 KB
RSS: 9136 KB
当将向量重新分配为大小1时,似乎没有释放用于大向量(100万双〜8 MB)的内存.
但是,如果使用标志-std = c 11进行编译,则输出将更改:
RSS: 1180 KB
RSS: 9112 KB
RSS: 1300 KB
现在,该内存似乎已由重新分配释放. C 11标准是否以某种方式对内存进行重新分配?
解决方法:
该库的实现者很可能会重用向量的容量,只要它大于您为其分配的向量的容量即可.这样,他们可以节省内存分配.
从C 11开始,我们进行了移动分配,因此,当您使用-std = c 11进行编译时,而不是重新使用容量,则将临时矢量移动到现有矢量中,并将原始矢量的内容移动到临时中.在表达式的结尾,临时变量被销毁,您现在有了一个容量较小的向量.
如果要缩小向量的容量,则应检出:reduce the capacity of an stl vector