野指针产生原因:
野指针主要是因为这些疏忽而出现的删除或申请访问受限内存区域的指针:
- 指针变量创建时未初始化
任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,指针变量在创建的同时应当将指针设置为NULL,或使它指向合法的内存。如果没有初始化,编译器会报错“ ‘point’ may be uninitializedin the function ”。 - 指针 free 或 delete 后未置空
有时指针在 free 或 delete 后未赋值 NULL,此时只是把指针所指的内存释放了,但并没有把指针本身干掉。此时指针指向的就是“垃圾”内存。释放后的指针应立即将指针置为 NULL ,防止产生“野指针”。 - 指针操作超越变量作用域
不要返回指向栈内存的指针或引用,因为栈内存在函数结束时会被释放。
野指针危害
野指针的问题在于,指针指向的内存已经无效,而指针没有被置空,引用一个非空的无效指针是一个未被定义的行为,也就是说不一定导致段错误,野指针很难定位到是哪里出现的问题
悬空指针
指针正常初始化,曾指向过一个正常的对象,但是对象销毁了,该指针未置空,就成了悬空指针。