【C++】野指针及其危害

【C++】 野指针及其危害

引言:小白在初期敲代码时最可能碰到的问题之一估计就是野指针了,因为它在写程序的时候一不注意就写出来了,且不容易被发现,调试半天可能也不会出结果。去找大佬一看,其实就是一个很简单的野指针问题,那么我们今天就来学习一下关于野指针的问题,以及怎么在敲代码时如何规避它。

什么是野指针呢?
答:“野指针”并不是NULL指针,而是在定义上没有初始化,值为随机,又或者是指向了已经被释放内存了的指针或是指向越界的变量作用域的指针。

野指针的成因

  • ①指针变量没有被初始化。首先我们要知道,任何指针变量刚被创建时不会自动成为NULL指针,它的默认值是随机的,可能会指向任意位置。所以,指针变量在创建时的最开始就应该及时对其初始化,要么将其置为NULL,要么让它指向一块合法的内存。
  • ②指针ptr被free或者delete之后,只是释放了ptr所指向的内存,而没有把指针ptr干掉,且没有及时被置为NULL,当后边用到它时,以为它任然是合法的。
  • ③指针操作超越了变量所在的作用域,意思是返回了指向栈内存的指针或引用,因为栈内存在函数结束时就会被释放掉。

野指针的危害
下面我们通过一段代码来分析一下:

1  short *bufptr;
2  short  bufarray[20];
3  short  var0X20;
4  *bufptr=var;
5  bufarray[0]=var;

解析

  • ①代码第1行,没有问题,声明了一个short*型的指针,并且没有初始化,为后边买下炸弹。
    ②代码第2行,没有问题,声明了一个20个元素的数组,每个元素都是short型的。
    ③代码第3行,没有问题,声明了short类型的变量var,并且初始化为0X20。
    ④代码第4行,有错误,此处将bufptr指针指向的内容赋值为var变量的值,因为bufptr在最开始并没有被初始化,是一个“野指针”,因此对他指向的内容操作是非常危险的,会导致程序崩溃。为了杜绝这种错误操作,我们可以将bufptr进行正确初始化,应该将第一行改为short *bufptr=(short*)malloc(sizeof(short)); ⑤代码第5行,没有问题。把bufarray的第一个元素赋值为变量var的值。

野指针危害总结

  • 1.指向不可访问的一段地址,触发段错误
  • 2.指向一个可用的,但是正在被使用的空间,如果在此时对这段空间解引用后,对其加以修改或者释放,但是这段空间正在被使用,这是非常危险的操作,程序会崩溃,数据也会可能被破坏

C/C++语言中使用指针的规则,避免野指针

  • 1、用malloc申请了内存之后,应该立即检查指针值是否为NULL,防止使用值为NULL的指针。
  • 2、动态申请操作必须和释放操作匹配,防止内存泄露和多次释放。谁申请,谁释放。
  • 3、牢记数组的长度,防止数组越界操作,考虑使用柔性数组,使用结构体struct来定义柔性数组。
  • 4、free指针之后必须立即赋值为NULL。
  • 7
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

L19002S

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值