我刚刚在一台只有12MB内存的QEMU虚拟机上执行了一个申请13MB内存的程序。不仅如此,我还浏览了内存并填充了垃圾数据。
void
large_mem(void)
{
#define LONGMEM 13631488
long long *ptr = (long long *)malloc(LONGMEM);
long long i;
if(!ptr) {
printf("%s(): array allocation of size %lld failed.\n",__func__,LONGMEM);
ASSERT(0);
}
for(i = 0 ; i < LONGMEM ; i++ ) {
*(ptr+i)=i;
}
free(ptr);
}
怎么可能?我本来期待一个分段错误。