可变重分配中的C 11内存释放

我试图了解有关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

上一篇:C语言 C99标准与C11标准的部分更改的函数对比


下一篇:Linux上的gcc 4.8.2-使用线程崩溃的简单程序