JProfiler的入门使用,流程介绍
JProfiler是安装在IDEA的插件,用来排查OOM(OutOfMemoryError)错误。生成Dump内存快照。
当程序发生内存溢出时,快速定位内存泄露位置。
注意:JProfiler有服务器端和客户端两个部分,都要安装,才能够正常测试使用。
1.首先写一段内存溢出的代码。
import java.util.ArrayList;
//Dump文件 -Xms1m -Xmx1m -XX:+HeapDumpOnOutOfMemoryError
public class DemoNative {
public static void main(String[] args) {
byte[] arr = new byte[1*1024*1024];
ArrayList<Object> arrayList = new ArrayList<>();
int count = 0;
try {
while (true){
arrayList.add(new DemoNative());
count = count +1;
}
}catch (Error e){
System.out.println("count"+count);
e.printStackTrace();
}
}
}
此时代码是无法正常执行,会报OOM的错误。
2.在VM options中进行配置。
-Xms1m -Xmx1m -XX:+HeapDumpOnOutOfMemoryError:设置内存初始大小为1m,内存最大大小为1M,并且打印Dump快照信息。
此时的程序执行结果:
3.打开Dump文件
打开目录后,往上层目录进行查找:找到和控制台输出相同的文件名。
4. 双击打开该文件,会自动进入JProfiler软件。
其中标红线的是比较常用的选择。
Classes:
Biggest Object:最大的对象
References:它的引用
Time:占用时间的分析
Heap Walker:堆
CPU views:CPU相关
Thread:线程相关
5.分析
根据Class可以定位到对应的类对象。
由于现在的没有跑其他的线程,看main线程中就能够定位到发生问题的具体代码行数。