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

本文详细介绍了遇到的C++内存溢出错误'HEAP CORRUPTION DETECTED',该错误通常在debug模式下出现,由new分配内存后操作不当引起。通过分析示例代码,指出错误原因在于未初始化的char指针和不安全的strcpy函数使用。解决方案包括初始化new分配的内存以及替换为更安全的strncpy函数,修改后的代码成功解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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.convertTo(homo, CV_32FC1
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值