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(使用前将#替换为@)