起因
最近在调试一个问题,调试过程中遇到了crash。信息是read access violation.
用vs 跟进去之后发生了很奇怪的事情。
现象
模拟的代码是这样的:
class a
{
public giveValue(int[] key, int[] values);
public map<int,int> mem;
}
somefunction ()
{
a mya=new a();
...
givevalue(....)
int key1=...
a.mem[key1];
}
大概就是这样,在givevalue中给mem这个map赋值,然后直接用类的mem成员使用。
程序崩溃在a.map[key1]这一行,从watcher里面看到是这个mem找不到成员了。mem的allocator变成了非法值0x00005.
重新运行,跟踪进givevalue,发现也正常赋值了。直到givevalue退出,mem里面都是对的。查看了mem的内存,发现在退出givevalue函数后内存并没有变,但是allocator变成了非法值。
原因
后来跟小伙伴们分享了这个奇怪的现象。大家集思广益,终于发现了原因,我运行的是release版的程序,但是其中我需要调试的一个库使用了debug版。
解决
后来把要调试的库替换成了release版,这个crash就消失了。
总结
release版和debug版的混用需谨慎。