`
kmplayer
  • 浏览: 497241 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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

阅读更多
问题:
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