JVM的框架知识了解之后,实际的项目里发生了OOM异常的话,怎么获取以及分析异常信息后怎么分析呢。右键选中"在OOM时生成dump"。在While中循环,引起Heap的OutOfMemory异常发生。有一个小知识点共享下,map进行containsKey的处理时,key如果是javabean对象,判断时使用的是对象的引用。最好key的数据类型定义为值类型等。点击“类”tab页,通过"大小"排序,可以看出java.lang.Integer占用了99%以上的空间。双击这一行,可以进入进去看到,各个Integer的具体内容。这里的目的是发生OOM,所以Integer的内容没有设值,进去可以发现值都是null。通过这几天的JVM复习,以及OOM发生时的dump分析,再次做项目时,头脑会更清晰一些。

JVM 心得 OOM时的堆信息获取方法与分析

JVM 心得 OOM时的堆信息获取方法与分析

JVM 心得 OOM时的堆信息获取方法与分析