OOM实战
public class Outmemory {
/**
* -Xms1m -Xmx1m
-XX:SurvivorRatio=8 //新生代中eden区域与Survivor区域的容量比例,默认值8,代表 Eden:survivor =8:1
-XX:+HeapDumpOnOutOfMemoryError
* @param args
*/
public static void main(String[] args) {
List<Aa> list = new ArrayList<>();//一个类,自己创建就行了,然后对应的list 改一下泛型
while(true){
list.add(new Aa());
}
}
/**
* -Xms1m -Xmx1m
-XX:SurvivorRatio=8 //新生代中eden区域与Survivor区域的容量比例,默认值8,代表 Eden:survivor =8:1
-XX:+HeapDumpOnOutOfMemoryError
* @param args
*/
public static void main(String[] args) {
List<Aa> list = new ArrayList<>();//一个类,自己创建就行了,然后对应的list 改一下泛型
while(true){
list.add(new Aa());
}
}
}
用mat分析 java_pid11024.hprof ... 默认生产进程号+.hprof文件。mat安装 直接help-》marketplace->搜索mat—》然后一路next。
**然后通过mat查看对象泄露对象到GCroots的引用链。于是找到泄露对象是通过怎样的路径与gc roots相关联,导致垃圾回收器无法自动回收他们。换句话说如果内存对象确实应该活着(业务场景确实需要,我的理解),那就应该检查虚拟机的堆参数,与物理机内存对比是否可以调大**
延展知识点,对象到底什么时候回收? 对象年龄? 大对象? 软引用?弱引用?虚引用?强引用?