`
nrx54nrx
  • 浏览: 12139 次
社区版块
存档分类
最新评论

关于malloc函数后free内存空间的疑问

 
阅读更多

关于malloc函数后free内存空间的疑问
2011年11月22日
   问题:
  malloc是开出内存空间。
  现在我写了这么一句:
  char *name;
  name=(char *)malloc(len*sizeof(char));
  name指针是个char指针,指向一个char数据,即只保留了一个char数据的长度信息.free的时候它如何知道开出的空间到底有多长?
  解答:
  (1)malloc是一个库函数,不是由操作系统提供的,绝大部分都是由编译器提供的库包自己实现的。malloc如何实现,依赖于不同的操作系统跟不同的c库。
  比如,在linux上面,malloc是调用brk系统调用进行内存分配的,而在windows则是HeapAlloc等等类似的系统函数分配内存。
  一般c库在初始化的时候都是一下子在堆中分配了一大部分内存,然后再根据自己的算法对这些内存进行分配。至于free怎么知道要free多少字节。其实很简单,因为每用malloc分配一个内存块,c库就要记住你分配的多少字节,一般情况下都是记在返回指针的前几个字节。
  (2)c库记忆就是开辟额外的空间记录分配内存的大小,开辟额外的空间去记录分配内存的大小也只是一个权宜之计,也只是c库玩的一种把戏而已。微软的c库这么做,gcc的c库这么做,但不代表其他所有编译器的c库都这么做。所以,通俗的讲,或者更一般的讲,用c库记忆更具有一般性。
  (3)比如char * buf1 = (char*)malloc (32); 
  那么buf1[-8]~ buf1[-1] 都是用来放管理信息的!特别是在windows下编程是如此. 
  buf1的管理结构(8bytes)  |  buf1真正可操作空间(32bytes)   |    下一个空闲堆的管理结构(8bytes)|两个双链表指针(8bytes)
  ↑                  ↑
  Free()根据这里提供的      buf1真正指向这里
  管理信息来回收内存
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics