再谈野指针问题Free Heap block xxx modified at xxx after it was freed

来源:互联网 发布:数据挖掘金融应用案例 编辑:程序博客网 时间:2024/06/06 13:13

Free Heap block XXXXXX modified at XXXXXX after it was freed

 向原创致敬   ↑   奋斗    

相信不少朋友碰到过以上问题,而往往苦于无法定位到错误的代码位置,其实出现该问题一般就是使用了野指针导致的.

 

 

那么何为野指针呢?

 

野指针与NULL指针不同.所谓野指针是指指针所指的内存已经回收,而继续使用该指针,导致未定义行为.

 

例如:

 

 

[cpp] view plaincopy
  1. char *p = new char[512];  
  2.   
  3.   
  4.   
  5. *p = '/0';  
  6.   
  7. delete[] p;  
  8.   
  9. *p = 'a'// 此处出现了野指针  

 

所以为了避免此类问题。往往采用删除后立即清空指针变量的方法

[cpp] view plaincopy
  1. delete []p;  
  2. p = NULL; // 进行置NULL  
  3. *p = 'a'// 这里调试器将给出提示,成功定位错误位置  


这样看似很好解决野指针的问题,其实不然,因为要知道内存删除与指针变量使用往往是脱节的。

例如:

[cpp] view plaincopy
  1. char *p = new char[512];  
  2. char *q = p;  
  3.   
  4.   
  5. *p = '/0';  
  6.   
  7. delete[] p;  
  8. p = NULL;  
  9.   
  10. *q = 'a'// q与内存删除代码往往不在同一地点,没办法指定q=NULL;所以照样出现了野指针。  


那么此类问题如何定位呢?

这里就要利用文章开头写的那个提示信息了。

Free Heap block d49418 modified at d49574 after it was freed

这句话的意思是,释放了内存开始为0xd49418的堆块后,堆块所在内存的0xd49574位置被更改了。

这样就好办了,我们只需要查找到0xd49418所在位置属于分配给了哪个对象,然后再定位0xd49574所处的成员变量

然后查找所有使用该变量并进行了变量内容的修改的代码就可以定位到错误位置了。再根据情况修改代码,避免内存释放后仍然进行修改即可。