assign 0 to _debugger_hook_dummy so that the function is not folded in retail
void __cdecl _CRT_DEBUGGER_HOOK(int _Reserved)
{
/* assign 0 to _debugger_hook_dummy so that the function is not folded in retail */
(_Reserved);
_debugger_hook_dummy = 0;
}
其实这个错误的原因主要是因为内存空间的重复分配时发生错误。
如下面:
CString str = L"userDefined"; 或者 str.Format(L"%s",L"userDefined");
str.Format(L"%s%s",str,L"bbbbbbb");
这样子就会导致上面的错误信息。这是因为用FORMAT会在内部根据格式化参数列表对字符串本身的内在空间进行重新分配
而如果直接采用字符串本身作为参数传入的话,会造成内在的冲突,而这个冲突是无法遇见的,即不会经常出现。
所以,为了避免上面的问题,应避免使用上述的方法。
CString temp= L"userDefined"; 或者 str.Format(L"%s",L"userDefined");
str.Format(L"%s%s",temp,L"bbbbbbb");
只需多采用一个变量即可。
* 注意:避免将字符串本身作为参数传入到使用FORMAT格式化列表的原来字符串中。
1.在很短的时间内创建多线程...
for (int i =0; i < 100; i++)
HANDLE handle = CreateThread(.....);
在1秒内一下子创建几十个线程有可能出现这种状况。
2. 在很短时间内访问同一个文件的操作,同时没有加锁
和1差不多吧,
3.多线程在很短的时间间隔内共同操作用户界面