delete 错用 delete[] 导致 Trigger Point Break

 在_DEBUG模式中, delete 最后会调用函数:

  1. extern "C" void __cdecl _free_dbg_nolock(
  2.         void * pUserData,
  3.         int nBlockUse
  4.         )        

该函数位于dbgheap.c ,  而delete[]也调用这个函数.

 

在该函数中,有一个检查函数:

 

  1.         /*
  2.          * If this ASSERT fails, a bad pointer has been passed in. It may be
  3.          * totally bogus, or it may have been allocated from another heap.
  4.          * The pointer MUST come from the 'local' heap.
  5.          */
  6.         _ASSERTE(_CrtIsValidHeapPointer(pUserData));

这里会形成一个Trigger Point

posted on   norsd  阅读(173)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏

导航

< 2008年8月 >
27 28 29 30 31 1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31 1 2 3 4 5 6
点击右上角即可分享
微信分享提示