C语言中, 为了避免野指针,是否可以在free和delete之后,把指针置为NULL就可以避免了?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言中, 为了避免野指针,是否可以在free和delete之后,把指针置为NULL就可以避免了?相关的知识,希望对你有一定的参考价值。
我觉得你说得对,因为free/delete只是删除由程序员自己分配的内存空间,但是指针本身还是要占用内存空间的,它可以指向新的内容,比如char *ch = new char [10];
……
delete [] ch;
之后,仍然可以打印ch和*ch,但是最后加上一行
ch = NULL;
之后,再对ch进行操作就会提示内存访问错误,"violation access…"
所以把不用的指针置为NULL是可取的。 参考技术A 不是在free 和delete 之后 应该在定义时候 把指针置为NULL 参考技术B 把指针置空确实可以有效的避免所谓“野指针”的出现 参考技术C 定义的时候和调用free、delete之后都需要设成NULL本回答被提问者采纳 参考技术D void func()
char *pCh=NULL;
pCh=new char(20);
if(NULL!=pCh)
memset(pCh,0,sizeof(char)*20);
if(NULL!=pCh)
free(pCh);
pCh=NULL;
C语言知识分享:野指针!野指针怎么样产生的?又怎么避免呢?
一、什么是野指针?
指针是C语言的灵魂,同时也是很容易让人犯错的重难点,用错了指针将是一个灾难。
指针变量的本质是值,这个特殊的值是一个内存地址值,而合法的内存地址包括定义的变量的地址(栈)、malloc函数申请堆内存返回的地址(但未使用free释放,是在堆空间动态申请)
需要注意的是,野指针不是NULL指针,通常NULL指针可以使用if语句来判断,但是C语言中没有任何方法用来判断一个指针是否为野指针!
二、野指针是怎么来的?
通常野指针是因为指针变量中保存的值不是一个合法的内存地址或者指向不可用内存的指针而造成的。
而且野指针往往会造成内存越界、段错误等难以找到的问题,下面分几种情况来说说野指针的由来。
局部指针变量没有被初始化
局部变量不像全局变量那样,不赋值会自动初始化为0,指针name指向的内存空间地址是随机的,不能向随机地址空间写数据。我们在定义局部指针变量时应该初始化为NULL,局部变量则初始化为0
使用已经释放过后的指针
malloc申请的堆空间释放后,意味着把这片内存归还到空闲链表,其它程序可以使用这片空间,如果其它程序使用了这个空间,可能导致其它程序莫名其妙的被关闭,所以一定要在释放过后将指针变量的值赋值为NULL。
指针所指向的变量在指针之前被销毁
func函数被调用的时候,栈区存放了局部数组p,func返回之后,栈顶指针退出,占用的内存已经被释放掉,此时指针s指向一个被释放掉了栈空间,如果栈空间值被修改了,就不会打印出预期结果,s就变成了一个野指针,所以我们绝对不要在函数中返回局部变量和局部数组的地址。
进行了错误指针运算
程序中在数组第1个元素a[0]被清除之后,指针p的值还继续减下去,而接下去的一次比较运算是用于结束循环的。但表达式p>= a(p >= &a[0])的值是未定义的。
为避免这种情况,一定要确保字符数组要以‘\\0’结尾,为防止内存越界,自己编写的内存相关函数需要指定正确的长度信息。
进行了错误的强制类型转换
上面的程序在64位下输出错误,32位下输出a的值1,在我们写嵌入式程序的时候,会将int类型的一个数据强制转换成一个指针类型用来表示寄存器的地址,这个时候就需要注意了。
怎么避免野指针?
知道了野指针产生的原因,避免方法就出来了,在指针的解引用之前,确保指针指向一个绝对可用的空间。
定义指针时,同时初始化为NULL
在指针解引用之前,先去判断这个指针是不是Null
指针使用完之后,将其赋值为NULL
在指针使用之前,将其赋值绑定给一个可用地址空间
来源:技术让梦想更伟大
作者:李肖遥
对于准备学习编程的小伙伴,如果你想更好的提升你的编程核心能力(内功)不妨从现在开始!
C语言C++编程学习交流圈子,QQ群:614504899【点击进入】微信公众号:C语言编程学习基地
整理分享(多年学习的源码、项目实战视频、项目笔记,基础入门教程)
欢迎转行和学习编程的伙伴,利用更多的资料学习成长比自己琢磨更快哦!
编程学习视频分享:
以上是关于C语言中, 为了避免野指针,是否可以在free和delete之后,把指针置为NULL就可以避免了?的主要内容,如果未能解决你的问题,请参考以下文章
C 语言指针数据类型 ( 野指针 | 避免野指针推荐方案 )