在我的单元测试中,我故意尝试引发一个OutOfMemoryError异常。我使用一个简单的语句,如下所示:
byte[] block = new byte[128 * 1024 * 1024 * 1024];代码可以在64位和jdk6u21 64位的Win7上运行。但是当我在CentOS5 64位的jdk6u21上运行它时,没有抛出OutOfMemoryError,即使我把数组的大小变大了。
有什么想法吗?
发布于 2010-07-16 15:32:16
如果您只想消耗所有内存,请执行以下操作:
try {
List<Object> tempList = new ArrayList<Object>();
while (true) {
tempList.add(new byte[128 * 1024 * 1024 * 1024]);
}
} catch (OutOfMemoryError OME) {
// OK, Garbage Collector will have run now...
}发布于 2010-07-16 10:31:28
Linux并不总是立即为您分配您所请求的所有内存,因为许多实际应用程序要求的内存比它们需要的要多。这就是所谓的过度提交(这也意味着有时它会猜错,可怕的OOM killer会攻击)。
为了你的单元测试,我会手动抛出OutOfMemoryError。
发布于 2010-07-16 13:05:51
128*1024*1024*1024=0,因为整型是32位的。Java不支持大于4 4Gb的数组。
https://stackoverflow.com/questions/3261513
复制相似问题