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