2757|1

61

帖子

3

TA的资源

一粒金砂(初级)

楼主
 

关于野指针 [复制链接]

野指针指的是指向“垃圾”内存的指针,不是NULL指针。出现“野指针”主要有以下原因:
(1)指针变量没有被初始化。指针变量和其它的变量一样,若没有初始化,值是不确定的。也就是说,没有初始化的指针,指向的是垃圾内存,非常危险。
(2)示例程序如下:
#include

int main()
{
       int*p;

       printf("%d\n",*p);

       *p=10;
       printf("%d\n",*p);

       return0;
}     
(2)指针pfree之后,没有置为NULLfree函数是把指针所指向的内存释放掉,使内存成为了自由内存。但是,该函数并没有把指针本身的内容清除。指针仍指向已经释放的动态内存,这是很危险的。
程序员稍有疏忽,会误以为是个合法的指针。就有可能再通过指针去访问动态内存。实际上,这时的内存已经是垃圾内存了。
关于野指针会造成什么样的后果,这是很难估计的。若内存仍然是空闲的,可能程序暂时正常运行;若内存被再次分配,又通过野指针对内存进行了写操作,则原有的合法数据,会被覆盖,这时,野指针造成的影响将是无法估计的。
示例程序如下:
#include
#include
#include
int main()
{
       intn=5,*p,i;

       if((p=(int *)malloc(n *sizeof(int)))==NULL)
       {
              printf("mallocerror\n");
              return0;
       }
       memset(p,0,n*sizeof(int));
       for(i=0;i
       {
              p=i+1;
              printf("%d",p);
       }
       printf("\n")
       printf("p=%p*p=%d\n",p,*p);
       free(p);
       printf("afterfree:p=%p *p=%d\n",p,*p);
       *p=100;
       printf("p=%p*p=%d\n",p,*p);
       return0;
}     
该程序中,故意在执行了“freep)”之后,通过野指针p对动态内训进行了读写,程序正常执行,也在预料之中。前面已经分析过,内存释放后,若继续访问甚至修改,后果是不可预料的。
(3)指针操作超越了变量的作用范围。指针操作时,由于逻辑上的错误,导致指针访问了非法内存,这种情况让人防不胜防,只能依靠程序员好的编程风格,以及扎实的基本功。
(4)不要返回指向栈内存的指针。在主调函数中,往往会通过返回飞指针,继续访问指向的内存。因此,指针函数不能返回栈内存的起始地址,因为栈内存在函数结束时会释放。

此帖出自Linux开发论坛

最新回复

谢谢分享,学习中  详情 回复 发表于 2016-4-11 12:03
点赞 关注(1)

回复
举报

30

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
谢谢分享,学习中
此帖出自Linux开发论坛
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条
Microchip 直播|利用motorBench开发套件高效开发电机磁场定向控制方案 报名中!
直播主题:利用motorBench开发套件高效开发电机磁场定向控制方案
直播时间:2025年3月25日(星期二)上午10:30-11:30
快来报名!

查看 »

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表