“野指针”(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