free()函数释放内存后的指针行为


一个指针释放后不置空的后果:

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;
}

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM