您的位置:首页 > 其它

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

2012-12-06 18:39 253 查看
转自:http://www.myexception.cn/other/491341.html

关于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真正指向这里 
  管理信息来回收内存 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: