malloc与free

关于malloc与free

1.      这两个函数是库函数,不是操作系统中真正对进程虚拟地址的释放(例如Linux的brk系统调用才是真正的申请和释放)

2.      free并不代表操作系统对于进程虚拟空间真正的释放,因此在释放后该块地址对于进程来说还是可以访问的(并不会引起非法地址访问的错误,在调用free后,库可能会将这段内存标记为一个很大得值,例如在windows下的0xfeeefeee,表示该块内存已经释放)。

3.      当进行堆的分配时,分配的空间会略大于申请的空间,因为在该申请空间的首部,库函数用来作为内存块的管理信息。

4.      free函数释放的空间(传入的参数)必须是由malloc,alloc,realloc三个函数返回地址之一,因为在free()函数中,需要根据此地址定位管理结构的地址,而管理结构记录了该块的地址,该块是否可重用等信息。

5.      并不是任意一个进程的合法地址都可以用free释放,因为定位管理结构地址的时候,必须使用malloc(或其他两个申请函数)返回的地址才能正确的定位真正的内存块管理结构。当然,该结构也是由C库所定义。

你可能感兴趣的:(malloc与free)