码迷,mamicode.com
首页 > 编程语言 > 详细

Java 性能分析工具-MAT

时间:2020-11-30 16:10:09      阅读:11      评论:0      收藏:0      [点我收藏+]

标签:out   esc   cep   inf   sys   port   rac   ext   asi   

简介
MAT 是Memory Analyzer的简称,他是一宽功能强大的Java堆内存分析器。多用于查找内存泄露以及查看内存消耗情况。 基于Eclipse开发,是一款免费的Java性能分析功能

下载安装

https://www.eclipse.org/mat/downloads.php

技术图片

分析dump文件里的GC Roots

  • 代码
package com.zhu.gc;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Scanner;

/**
 * @describe: GCRootsTest
 * @author: zhuCw
 * @date: 2020/11/24 18:30
 */
public class GCRootsTest {
    public static void main(String[] args) {
        List<Object> numList = new ArrayList<>();
        Date birth = new Date();

        for (int i = 0; i < 100; i++) {
            numList.add(String.valueOf(i));
            try {
                Thread.sleep(10);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }

        System.out.println("数据添加完毕,请操作:");
        new Scanner(System.in).next();
        numList = null;
        birth = null;

        System.out.println("numList、birth已置空,请操作:");
        new Scanner(System.in).next();

        System.out.println("结束");
    }
}
  • 使用JVisualVM在输入字符前后分别生成两个dump文件
  • 使用MAT打开两个dump文件(file -> open heapdump)
    技术图片
  • OpenQueryBrower-> java basics -> GC Roots
    技术图片
  • 第一个dump 里main线程里找到了arrylist 和 date为gc root
    技术图片
  • 第二个dump 里main线程里没有找到了arrylist 和 date为gc root(因为置为null了)
    技术图片

Java 性能分析工具-MAT

标签:out   esc   cep   inf   sys   port   rac   ext   asi   

原文地址:https://www.cnblogs.com/zhucww/p/14037371.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!