现象:
具体场景出现在new分配内存中,VS输出信息为: Critical error detected c0000374 在 X64正常,X86崩溃
是在分配内存时发生的,但是这里是内核模式地址区域,堆管理器是不可能指定这个地址的.所以很明显,堆数据被溢出篡改了,即堆破坏问题.接下来就要寻找是哪里发生了数据溢出。
分析:
debug 看了一下,正常分配内存,一般来说造成这种情况的原因是数组越界了。
如果不是这次造成的,哪么可能是上次内存赋值都越界了,造成了堆被破坏了。
解决方案:
查找代码中上个内存分配的位置,在长度加1,正常。问题解决。
int Buflen = 100;
_PRTA(unsigned char,ScaleBuf,Buflen + 1);//
这里是使用的智能指针;unsigned char,正常的话不需要存放结束符号,理论上这里不需要加1。
总结:
遇到这里问题,基本是内存赋值越界了, 查看一下上面的代码是不是这种情况;
1.分配内存少 1,2.内存赋值越界,长度超了。如memset();