野指针分析

1. 野指针的概念   所谓的野指针,就是说指针指向的那块内存,你没有合法操作的权限,也就是指针指向非法的内存空间,这样的指针就叫做野指针。 2. 野指针产生的原因 (1) 指针变量未初始化         任何指针变量刚被创建时不会被自动置为NULL,它的缺省值是随机的,所以这块内存,所以指针变量在创建时,要么初始化让它指向一块合法的内存,要么置为NULL。

 #include <stdio.h>
 #include <stdlib.h>

 int main(void)
 {
      //int *p; //指针变量没有被初始化,值是随机的
      int a = 3;
      //int *p = NULL; //初始化时将指针置为空
      //int *p = &a; //初始化时将指针指向a
      printf("%d", p);
      return 0;
 }

(2) 指针指向的内存释放后之后未置空         指针指向的内存被free或者delete释放后,指针的值仍然为刚刚被释放的那块内存的首地址,但是此时指针已经失去了对那块内存的合法访问权限,所以在free或delete一块内存后,要及时把指针置为NULL。

 #include <stdio.h>
 #include <stdlib.h>

 int main(void)
 {
     int *p = NULL;
     printf("before malloc p:%d\n", p);

     p = (int)malloc(sizeof(int)); //malloc一块新内存,让p指向这块内存
     printf("after malloc p:%d\n", p); //打印p的值

     *p = 3;
     printf("*p:%d\n", *p); //打印p指向的那块内存空间的值

     free(p); //释放p指向的那块内块空间
     printf("after free p:%d\n", p);
     // 注意:此时p中的值没有发生变化,但是free内存后已经失去了对堆上那块内存的合法操作性
     *p = 4; //非法向内存中赋值,程序可能会崩溃
     printf("*p:%d\n", *p);

     return 0;
 }

(3) 指针操作超越变量作用域      不要返回指向栈内存的指针或引用,因为栈内存在函数结束时会被释放。

 #include <stdio.h>
 #include <stdlib.h>

 char *getStr()
 {
         char p[] = "abcdefg"; //在getStr()函数内部声明一个局部数组,p在getStr()函数的栈上        
         printf("getStr %s\n", p);
         return p; //返回这个数组的首地址
 }

 int main(void)
 {
         char *pStr = getStr(); //接收getStr()函数中局部数组的首地址
    //注意:当getStr()函数调用结束后,它内部的局部变量就会被释放,在main函数中打印pStr时,可能会输出”abcdefg”,但不代码这样是合法的.
         printf("main %s\n", pStr); //打印pStr所指向的内存块中的值
         system("pause");
         return 0;
 }

关键点:上面的程序在运行时可能并不会产生错误,但并不代表这样做是正确的,理解野指针的关键,就是指针指向的内存是否可以被合理合法访问。

3. 避免产生野指针 (1) 初始化时置 NULL (2) 指针指向的内存释放后之后将指针置为空

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Python

Django中请求的生命周期

1. 概述 首先我们知道HTTP请求及服务端响应中传输的所有数据都是字符串. 在Django中,当我们访问一个的url时,会通过路由匹配进入相应的html网页中...

25010
来自专栏Aloys的开发之路

C/C++中的abort、atexit、exit和_Exit

     这几个函数都在头文件#include <stdlib.h>中声明。exit、_Exit与abort函数使程序终止,控制并不返回到这些函数的调用者。 e...

1819
来自专栏小狼的世界

PHP中的正则表达式及模式匹配

PHP中对于正则处理文本提供了两种方式,一种是PCRE方式(PCRE库是一个实现了与perl 5在语法和语义上略有差异(详见下文)的正则表达式模式匹配功能的函数...

812
来自专栏微服务生态

java instrument agent 原理小结

java -cp classes:lib/byte-buddy-1.4.16.jar -javaagent:test-1.0-SNAPSHOT.jar com....

473
来自专栏blackheart的专栏

[C#1] 10-事件

事件概述 CLR的事件模型建立在委托的机制之上。定义事件成员的类型允许类型(或者类型的实例)在某些特定事件发生时通知其他对象,事件为类型提供了一下三种能力: 1...

1816
来自专栏我和PYTHON有个约会

爬虫正传-江湖路远-0105-谁的刀快谁就有理

在web操作领域,为了减轻响应数据的体积和保证数据完整性的考虑,可以在浏览器允许的情况下,将数据压缩返回,压缩操作方式目前一般支持主流的两重操作方式[Accep...

542
来自专栏微信公众号:Java团长

图说Java —— 理解Java机制最受欢迎的8幅图

下面的8幅图来自于 Program Creek 的 Java教程 ,目前这是该网站最受欢迎的文章. 希望本文能帮你回顾你已经知道的那些知识。如果图片讲解的不够清...

693
来自专栏水击三千

SQL语言学习-数据操纵语言

一般而言,数据库中数据的生命周期包括数据插入以及更新、数据删除3个阶段。首先需要用户或者系统将数据插入表。然后,对数据的使用,包括数据的检索以及数据的更新。最后...

28010
来自专栏互联网杂技

express中app.use和app.get的区别及解析

写在前面:最近研究nodejs及其web框架express,对app.use和app.get没理解清,以致踩了坑浪费不少时间,我根据自己实践及总结出此博客,若有...

3416
来自专栏青枫的专栏

c语言基础学习10_关于文件操作的复习

============================================================================= 如果...

440

扫码关注云+社区