C语言中的malloc和free

最近在研究php自定义函数的实现,其中php自定义函数在传递参数时,是放到人为的一个栈中,这个跟写C程序时,参数入栈的这个栈还不一样,其中延伸到了 malloc 以及free

有人说在free(p)后,要将p设置为NULL, 在查找了一翻资料后,大体上弄明白了是怎么回事

参考资料: http://bbs.csdn.net/topics/200069568

 

malloc是向OS要一块内存,在OS中会用一个链表,将空闲的内存地址组织起来,当申请内存时,OS会链表中取出相应大小的内存给申请者

例如

int *p=NUILL;
p=(int *) malloc(4); //p指向的内存地址 假设为:0x005

 

free 释放内存 , 将这个内存重新放到上面的链表中,内存里的内容不一定被清空,可能下次分配给另一个申请者后,会被覆盖

free(p); //执行free函数后,p的值仍为0x005,只不过这块内存已经被被打上可再次使用的标记回收了再次使用会提示 非法操作
P=NULL; //将p的值设置为null

 参考这里 , 为什么 free的时候只传一个地址,就能将我们分配的那段内存置为可再次使用,见这里

posted @ 2014-08-03 16:11  taek  阅读(398)  评论(0编辑  收藏  举报