为什么在delete this;
调用以下函数后调用堆栈?
msvcr110d.dll!_VEC_memset(void * dst, int val, int len)
请注意operator delete
没有超载。
答案 0 :(得分:7)
在Microsoft C / C ++运行时库的调试版本中,delete
使用0xDD
将释放的内存设置为memset
。这就是你在callstack中看到memset
的原因。你在发布版本中没有看到它。
同样,当通过new
分配内存时,新分配的内存设置为0xCD
。
您可以在此处查看部分详细信息 - https://msdn.microsoft.com/en-us/library/974tc9t1.aspx
答案 1 :(得分:3)
可能是你在调试模式下工作。在这种情况下,如果某人继续阅读释放的区块,则通常会填充释放的区域以便及早发现。
此外,当稍后重新使用该块时,可以检测是否有人在删除后写入某个区域。