有时,我会有一个像以下一样的错误:
unsigned int* x = calloc(2000,sizeof(unsigned int)); printf("%d",x[2000]);
我已超出分配区域的末尾,因此我在运行时获得了EXC_BAD_ACCESS信号.我的问题是:这是如何被发现的?看起来这只会默默地返回垃圾,因为我只关闭了一个字节,而不是整页.系统的哪一部分阻止我在x 2000返回垃圾字节?
解决方法
内存系统在其内存字段的开头和结尾都有标记值,超出了分配的字节数.释放内存时,它会检查这些值是否完好无损.如果没有,它告诉你.