HEAP CORRUPTION DETECTED报错说明及解决方案

HEAP CORRUPTION DETECTED

Bug说明

最近写代码时遇到了一个Bug,报错如下图

Debug Error!
Program:工程位置
HEAP CORRUPTION DETECTED:after Normal block(#xxxxxx)at 0x xxxxxxxxxxxxxxxx
CRT detected that the application wrote to menory after end of heap buffer
在这里插入图片描述
原因:

这是典型的内存溢出错误,常在内存的delete处发生,而且一般在debug版本中可能出现,release版本中可能并不报错。

出现这个错误的原因一般都是操作new申请的内存溢出,因为在c++中,如果用new分配一段内存,操作的时候改变了该部分的大小,在delete时就会出错。比如说如下部分:

char* p=new char[5]
strcpy(p,"aaaaa");
delete[] p;

这段代码就会出错,因为申请了一个size为5的内存,但是strcpy过去了一个size为6的字符串,因此破坏了这个指针,运行debug版本的时候就会出现先前的错误,但是在release版本中,溢出一个字节的内存很有可能是没有错误的,然后潜在的隐患是肯定存在的,因此,我们在debug遇到这样的错误时候一定要仔细检查对new出的指针的操作。

问题的解决

经调试,我发现我的代码在下面这部分出现了问题:

bool writecalibrationpara(Mat &homo, string filepath)
{
   
	//ini文件写入
	homo.convert
  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值