ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

HEAP CORRUPTION DETECTED 错误原因与解决

2021-08-10 21:32:42  阅读:184  来源: 互联网

标签:错误 int DETECTED 内存 HEAP fBuff new include CORRUPTION


一、错误如下:

    

 

 

   这个错误是说在0x01F641A8处发生堆问题,下一句是说在堆buffer末尾内存中写入了数值。

二、错误原因

  这个问题显然在动态分配、释放时内存才会发生的。在解决这个问题问题前首要要了解在new和delete时堆中的内存是怎么分配的,是什么内存结构?

引用《c++反汇编与逆向分析技术揭秘》中的内容:

    

    

 

 

   

 

 

 

  从上面的知识可以看出,在使用new进行堆空间分配的时候,实际上每个堆节点采用双链表的数据结构,在内存中赋予一个结构体的内存大小,这个结构体包含了上、下一个堆的地址、本次堆数据分配的大小、堆的越界标示符等信号。

在看看我的程序,其中的一段源程序是:

3、错误范例代码

  出现这种错误一般都是使用者指针时,开辟了一块空间,但是使用时却超出了这块范围,程序在释放内存时找不到堆的越界标示符,无法释放这块内存导致的错误。

  如下代码,开辟了4个int内存,但是使用时,却使用了后面的4个字节,就会导致程序崩溃。

#include <iostream>
#include <windows.h>

int main()
{
    int* nBuff = new int[4];

    for (int i = 0; i < 5; i++)
    {
        fBuff[i] = i;
    }

    delete []fBuff;

  return 0; }

 

标签:错误,int,DETECTED,内存,HEAP,fBuff,new,include,CORRUPTION
来源: https://www.cnblogs.com/zwj-199306231519/p/15125872.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有