一个指针释放后不置空的后果:
free(p)之后原本那块内存的数据已经被释放了,内存重新收回。但此时的指针变量依然指向那块内存,在以后的代码中若不小心继续调用指针变量,会出现不可预料的错误。
不置空的话,在后面由于无法检测指针的合法性,很可能误以为p合法,直接访问有可能会造成程序崩溃。
我们在平时编程时,对空指针很容易检测(if(NULL==p)),但是对于非法指针p不为空,我们是无法检测到的(即野指针)。
防止对一个已经释放的指针多次释放造成程序崩溃,但是对一个null指针多次释放是合法的。
所以,我们在free后一定要将指针置空!!!!!!
注意:
内存泄漏的情况的产生是:例如:用int* p=(int*)malloc(sizeof(int));让p重新指向其它,这样用malloc()开辟的空间就找不到了,造成内存泄漏。
代码展示内存释放之后指针的行为:
#include <stdio.h> #include <stdlib.h> int main() { // 申请有num个元素的整型数组 int num = 0; scanf("%d", &num); int* p = (int*)malloc(sizeof(int) * num); if (p == NULL) { printf("内存分配失败\n"); } else { for (int i = 0; i < num; i++) { p[i] = i; printf("%d\n", p[i]); } // 内存释放前后,指针的值不变 printf("%p\n", p); free(p); printf("%p\n", p); p = NULL; //内存释放以后,要将指针置空(NULL),符合软件工程规范 // printf("%d\n", p[2]); //内存置空,在程序测试时可以及时发现引用错误 } return 0; }