C语言中的malloc和free

时间:2023-12-23 12:38:14

最近在研究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(); //p指向的内存地址 假设为:0x005

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

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

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