运行环境 WIN10 操作系统 JDK1.8 JVM 参数 -Xmx 5m
public class OOMObject {
private byte [] bytes = new byte[1024*1024*3];
}
在 for 循环中不断的创建对象。
for (int i = 1; i < 1000; i++) {
System.out.println(i);
new OOMObject();
}
打印到 299 时发生 OOM
java.lang.OutOfMemoryError: Java heap space
Dumping heap to D:\account\java_pid14828.hprof ...
Heap dump file created [2156653 bytes in 0.035 secs]
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at test.OOMObject.<init>(OOMObject.java:9)
at test.OOMSample.main(OOMSample.java:14)
重试多次,都是打印到 200-400 时发生了 OOM
for (int i = 1; i < 1000; i++) {
System.out.println(i);
new OOMObject();
Thread.sleep(100);
}
在 for 循环中加入 sleep。却能顺利跑完程序。
请教一下各位大佬,怎么合理的解析这种现象呢。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.