DoubleLi

qq: 517712484 wx: ldbgliet

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  4737 随笔 :: 2 文章 :: 542 评论 :: 1615万 阅读
< 2025年3月 >
23 24 25 26 27 28 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

在程序中发现一下代码:

复制代码
复制代码
int CHmcVideoMgt ::OnGetDiskRunningInfo( SOCKETPARAM *pSocketInfo ,Json:: Value Param )
{
        int iArrayLen = Param[ _T("NUM" )].asInt();
         .....              
        LPDiskRunningInfo  pDiskRunningInfo = new DiskRunningInfo[iArrayLen ];       
        int nResult = HMCBLL_GetDiskRunningInfo(pDiskRunningInfo ,iArrayLen);
      
             SAFE_DELETE_POINTER_ARRAY (pDiskRunningInfo);
        return E_SUCCEED ;
}
复制代码
复制代码

 

代码中没有判断 iArrayLen 的值为0的情况, 如果iArrayLen =0,  
LPDiskRunningInfo   pDiskRunningInfo new DiskRunningInfo [iArrayLen ]
执行成功, 而且指针也可以正常的赋值和操作. 
但是在删除的时候弹出堆栈异常, 提示"其原因可能是堆被损坏".
 
c++是不允许定义长度为0的数组的, 如果定义 char sz[0]; 编译器报错: error C2233: Target of operator new() : 包含大小为零的数组的对象数组是非法的.
 
但是在new一个长度为0数组时,编译不报错,   也返回一个正常的指针地址,  但是实际没有分配内存,  当修改数据时就会导致内存被破坏. 当被破坏的内存恰好被使用时就会导致异常.
posted on   DoubleLi  阅读(2192)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2012-10-25 JavaScript 操作 COM 控件
2012-10-25 引入js文件标签中的属性for ,event 用法
2012-10-25 mfc在控制多显示器的使用方法
点击右上角即可分享
微信分享提示