Chinaunix首页 | 论坛 | 博客
  • 博客访问: 33749
  • 博文数量: 20
  • 博客积分: 1410
  • 博客等级: 上尉
  • 技术积分: 175
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-28 14:38
文章分类

全部博文(20)

文章存档

2010年(20)

我的朋友
最近访客

分类: C/C++

2010-03-21 22:19:00

“野指针”不是NULL指针,是指向“垃圾”内存的指针。人们一般不会错用NULL指针,因为用if语句很容易判断。但是“野指针”是很危险的,if语句对它不起作用。野指针的成因主要有两种:
  一、指针变量没有被初始化。任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,它会乱指一气。所以,指针变量在创建的同时应当被初始化,要么将指针设置为NULL,要么让它指向合法的内存。
  二、指针p被free或者delete之后,没有置为NULL,让人误以为p是个合法的指针。别看free和delete的名字恶狠狠的(尤其是delete),它们只是把指针所指的内存给释放掉,但并没有把指针本身干掉。通常会用语句if (p != NULL)进行防错处理。很遗憾,此时if语句起不到防错作用,因为即便p不是NULL指针,它也不指向合法的内存块。例:
  char *p = (char *) malloc(100);
  strcpy(p, “hello”);
  free(p); // p 所指的内存被释放,但是p所指的地址仍然不变
  if(p != NULL) // 没有起到防错作用
  strcpy(p, “world”); // 出错
  另外一个要注意的问题:不要返回指向栈内存的指针或引用,因为栈内存在函数结束时会被释放。
阅读(466) | 评论(0) | 转发(0) |
0

上一篇:RTP与RTCP协议介绍

下一篇:extern

给主人留下些什么吧!~~