C/C++中遇见的问题集

1.问题1:

1)问题:

HEAP CORRUPTION DETECTED:after Normal block(#XXXX)at 0xXXXX.

CRT detected that the application wrote to memory after end of heap buffer.

 翻译一下错误提示:

HEAP(堆) CORRUPTION(不正确,破坏) DETECTED(被检测到):after(在什么之后) Normal(正常的) block(块,内存块)(#XXXX)at 0xXXXX.
CRT(C/C++运行时库) detected that the application wrote to memory after end of heap buffer.检测到应用程序在堆所在范围的后面的位置写内存。


2)分析:

    这种情况就是堆被破坏。堆被破坏,基本是发生在释放内存的时候。分配内存是不会有堆被破坏的情况的。

    堆被破坏的情况:释放了不属于自己的内存、释放超过自己拥有的内存量。当然,如果释放的量少于拥有的内存量,会导致内存泄漏,一般会有语法错误。比如直接不加[]来释放指向一个数组的指针。

错误原因:

    这是典型的内存溢出错误,常在内存的delete处发生,而且一般在debug版本中可能出现,release版本中可能并不报错。
    出现这个错误的原因一般都是操作new申请的内存溢出。因为在c++中,如果用new分配一段内存,操作的时候改变了该部分的大 小,在delete时就会 出错。比如说如下部分:
char* p=new char[6];  
strcpy(p,"aaaaaa");   //注意这里!!!分配的数组大小应为6+1,因为最后还有一个'\0'!
delete[] p;
    这段代码就会出错,因为申请了一个size为6的内存,但是strcpy过去了一个size为7的字符串。因此破坏了这个指针,运行debug版 本的时候就会出现 先前的错误,但是在release版本中,溢出一个字节的内存很有可能是没有错误的。然后潜在的隐患是肯定存在 的。因此,我们 在debug遇到这样的错 误时候一定要仔细检查对new创建的指针的操作。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值