您的位置:首页 > 编程语言 > C语言/C++

指针赋值为NULL;是什么意思呢?

2014-04-02 09:41 375 查看

int *p=NULL;这个NULL是什么意思?

    网上百度了下,有人说NULL=0;是在头文件中定义的;

    首先要说的是:非堆分配的内存是不需要free的。

    再说p=NULL;指针的变化是 p指向了一个地址为0的内存,这就提醒别人不要对这个指针进行解引用的操作。NULL其实就是0x0。p=NULL后,p指向0x0这个地址。此处的地址,你没有访问权限。

     空指针指没有定位内存的指针,值为null(0),你使用new或者malloc申请了指针p,使用后delete或者free,你必须将指针值设置为null,否则,p将成为一个非法指针,后续代码如果使用到该指针有可能会造成系统崩溃(内存不可以读不可写),或者,破坏自身有效内存数据(释放后,又在申请作为别的用途,恰巧系统分配了同一块内存)

     free(p)是只是将malloc申请的内存空间释放,在不改变free()函数的原型前提下是无法做到P=NULL的,P=NULL相当于空指针,不指向任何有效的对象。绝对不允许间接使用空指针,否则程序会得到毫无用处的结果或者全部是零的值,或者会突然停止。P=null,之后,p还是原来的类型的,不变的。

    比如说 我定义了一个整形变量 int a = 1;  同时定义了一个指针p指向这个变量a: int  *p = &a;

但我用完这个变量和指针的时候我把指针所指向的内存空间释放掉:free(p);这个时候p所指向的内存空间里面的数据1被清空的,但是指针p里面仍然存有一个地址(原来指向a变量内存空间的地址),此时通常再要把指针p设置成空指针:P = NULL。我的问题来了:从free(p);这条语句到p = NULL;这条语句,指针p的状态发生了哪些变化,到底什么样的指针才叫空指针?是不是P = NULL;之后,p里面所存放的地址就为空了?是这样理解吗?此时p还有指向的数据类型吗?比如说p还是一个int *型的指针吗?

 还有通常用if (p != NULL)来预防错误,就是说如果当指针p为空指针的时候,这个指针就最好不要用,要不然可能会发生内存泄露、空指针一场等错误,为什么呢?

1. int *p = &a; 这样的指针不可用 free , free 只是针对 malloc, realloc 的内存进行释放。

2. 空指针是指指针指向地址0,如果是你分配的内存,并且使用 free 释放,然后把指针置成 0 ,只是为了不进行非法的引用。



char* tmp = (char*)malloc(1024);

free(tmp);

tmp = 0;

在 free 后,如果后面再引用 tmp, 因为是个空指针,会导致进行崩溃。

如果不置为0,比如

char* tmp = (char*)malloc(1024);

free(tmp);

char* tmp2 = (char*)malloc(1024);

memset(tmp, 0, 1024);

这样,由于堆管理特性,很可能 memset(tmp, 0, 1024)写了 tmp2 指向的空间。

这样,释放完 tmp 后,再使用它,谓之野指针。

使用野指针会造成不可预期的后果,而使用空指针会造成比较确定的后果:崩溃。

所以 释放完后给指针赋成空,很大程度是避免以后错误地使用指针。



free(p)//报告系统,我要释放内存,系统就将该内存块标记为未使用,但不影响p的值

p = NULL//free被执行后,你需要将该指针标记为空,因为p指向的内存以被系统收回,不属于你的程序

这两个语句一般是在一起使用的

总结:为了避免野指针,定义指针的时候必须给指针初始化(以防指针空间的数据没有及时清空),用free(P)释放掉指针所指的内存空间后,必须立即同时把p赋值为NULL,避免后面程序指针P而导致意想不到的错误,甚至系统崩溃!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息