“野指针”(Dangling pointer)的问题

1. malloc() 内存之后,要使用memset()初始化内存。

    否则,有些代码默认该内存区所有内容为0,就会出错

2. 数据结构的内存释放有一定顺序。首先 free() 内嵌的结构,然后再 free() 大的结构。

    否则,就会造成”野指针“。


“野指针”不是NULL指针,是指向“垃圾”内存的指针。在一般情况下不会错用NULL指针,因为用if语句很容易判断。但是“野指针”是很危险的,if语句对它不起作用。


野指针的来源:

1、指针变量没有被初始化。任何指针变量刚被创建时不会自动成为NULL指针,它的默认值是随机的,它会乱指一气。
2、指针p被free或者delete之后,没有置为NULL,让人误以为p是个合法的指针。
3、指针操作超越了变量的作用范围。这种情况让人防不胜防。


参考文献:

1. http://www.cnitblog.com/mantou/archive/2005/10/07/3107.html

2. [DEBUG]记一次野指针调试

3. http://en.wikipedia.org/wiki/Dangling_pointer

posted @ 2011-08-12 16:37  bambreeze  阅读(185)  评论(0编辑  收藏  举报