首页 > 代码库 > C语言中的malloc和free

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