JProfiler-----入门使用

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线程中就能够定位到发生问题的具体代码行数。
在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章