杜绝“野指针”

以下内容取材于《高质量C语言编程指南》,原作者林锐,就职于上海贝尔网络应用事业部。特此鸣谢!


一般人可能会误以为“野指针”是NULL指针,其实不是。“野指针”是指向垃圾内存的指针,它是程序稳定运行的巨大威胁。

“野指针”的主要产生于下列两种情况:

1、指针变量没有被初始化。指针变量刚被创建时并不会自动成为NULL指针,而是随机指向某一块内存,这样的指针便成了野指针,如:

char *p; // 随机指向某一块内存

2、指针指向的内存被 free 或 delete 后,没有赋值为NULL,因而指向了一块已经被释放了的内存,这样的指针也变成了野指针,如:

char *str = (char*)malloc(100*sizeof(char));
free(str);
// str = NULL; // 若没有将str赋值为NULL,str便成了“野指针” 
还有一种情况也会出现“野指针”,那就是当指针操作超越了变量的作用范围时,例如:

class A
{
  public:
    void Func(void)
    { 
      cout << “Func of class A” << endl; 
    }
};
void Test(void)
{
  A *p;
  {
    A a;
    p = &a;          // p 是一个正常的指针,指向一块有效的内存
  }                  // a 的生命周期在括号处结束,a 被自动释放
  p->Func();         // 此时,p 已经野性十足,因为它指向了一块被释放了的内存,摇身一变成为了“野指针”
}
为什么要杜绝“野指针”?

        通常情况下,人们会使用 if (p != NULL) 来进行防错处理,但对于“野指针”来说,这样的 if 语句完全不起作用,因为 p 虽然不是NULL,但是却指向了非法的内存块。“野指针”如果不加以杜绝,很可能在程序中产生一些意想不到同时又极难调试出来的BUG,因此,杜绝“野指针”应该成为程序员下意识的行为。

        杜绝“野指针”的主要方法有:

        1、声明一个指针变量时,立即进行初始化,即分配一块内存,或是指向NULL;

        2、使用 free 或 delete 后,立即将指针赋值为NULL。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值