C 中的堆损坏

2024-03-24

int main ()
{
    int * b;
    b = (int*) malloc (1);
    *b=110000;
    free (b);
    return 0;
}

为什么堆损坏发生在free (b);?

IMO,堆损坏已经发生在*b=110000;.


malloc()的参数是要分配的字节数。您需要使用:

b = (int*) malloc(sizeof(int));

您分配的块太小,然后向其中写入的字节数超过了分配的字节数,这会覆盖该块旁边的簿记信息,从而损坏堆。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C 中的堆损坏 的相关文章

随机推荐