内存分析工具-MAT(Memory Analyzer Tool)

首先查看如下代码,main函数中有一个成员变量map,map里被循环放入对象Hanson,hanson持有姓名和age还有friends字段,friends字段为字符串数组,此应用会造成内存增长。

package com.hanson.heap;

import java.util.HashMap;
import java.util.Map; public class App {
public static void main(String[] args) throws InterruptedException {
Map<String,Hanson> map = new HashMap<String,Hanson>();
int counter = 1;
while(true) {
Thread.sleep(1);
Hanson h = new Hanson();
String [] friends = new String[counter];
for (int i = 0; i < friends.length; i++) {
friends[i] = "friends"+i;
}
h.setAge(counter);
h.setName("hanson"+counter);
h.setFriends(friends);
map.put(h.getName(),h);
if(counter%100==0)
System.out.println("put"+counter);
counter++;
}
}
}

模拟内存溢出程序

使用参数-Xms200m -Xmx200m –Xmn200m -XX:+HeapDumpOnOutOfMemoryError,指定内存200m并启动应用,并且在内存溢出时dump堆信息。使用jstat –gcutil ${pid} 1000 可以看到内存逐渐增长。

使用jmap -F -dump:format=b,file=${file path} ${pid},导出堆内存快照,并使用MAT工具进行分析。

可以在OverView中看到有一个App对象占用了较大内存,共计150.4MB,并且下方还有许多功能接下来逐一介绍。


名词概念

Shallow Size (对象自身占用的内存大小)

对象自身占用的内存大小,不包括它引用的对象。
针对非数组类型的对象,它的大小就是对象与它所有的成员变量大小的总和。当然这里面还会包括一些java语言特性的数据存储单元。
针对数组类型的对象,它的大小是数组元素对象的大小总和。

Retained Size (被GC后Heap上释放的内存大小)

Retained Size=当前对象大小+当前对象可直接或间接引用到的对象的大小总和。(间接引用的含义:A->B->C, C就是间接引用)
换句话说,Retained Size就是当前对象被GC后,从Heap上总共能释放掉的内存。
不过,释放的时候还要排除被GC Roots直接或间接引用的对象。他们暂时不会被被当做Garbage。

上图中,GC Roots直接引用了A和B两个对象。
这里不包括D对象,因为D对象被GC Roots直接引用。
如果GC Roots不引用D对象呢?
A对象的Retained Size=A对象的Shallow Size
B对象的Retained Size=B对象的Shallow Size + C对象的Shallow Size

此时,
B对象的Retained Size=B对象的Shallow Size + C对象的Shallow Size + D对象的Shallow Size

out going(查看对象为什么消耗内存)

可以使用右键àlist objectàwith outgoing references,此类对象持有的其他对象。

可以看到此对象friends字段的字符串数组消耗了很多内存。


in going(查看对象被谁引用)

可以使用右键àlist objectàwith ingoing references,其他对象持有的此类对象。

可以看到Hanson对象都被java.util.HashMap @ 0xfb6d7f78这个HashMap所持有,并且此Map都被主线程所持有。


path to GC root (对象没被释放掉的引用)

到GC root的路径

Merge Shortest path to GC root (对象没被释放掉的引用)

到GC root的最短路径,右键 merge shortest path to gc root -> exclude all phantim/weak/soft etc. references:查看此对象没被释放掉的原因,只保留强引用。

可以看到,此类没被释放是因为java.util.HashMap @ 0xfb6d7f78这个HashMap所持有,此map被主线程所持有,与上面结论一致。


Histogram

堆内所有类的统计信息,包含类的实例数量和占用的空间。如果此处包含了自己的类就需要注意是否此类创建过多。默认的大小单位是 Bytes,可以在 Window – Preferences—Memory Analyzer-- 菜单中设置单位。

可以通过filter搜索出自己的类,可以看到内存中共有2153个Hanson对象,占用了0.05MB内存,个数与输出一致(此处代码我用了取模,整百打印)。


Dominator Tree

列出了堆中最大的对象,并且引用此对象的其他对象。

如上图,可以很清晰的看到最大的对象是main函数的线程,是其中的java.util.HashMap @ 0xfb6d7f78这个map消耗内存,此map被主线程引用。


Top Consumers

按类、对象、包分组,列出最消耗资源的类、对象、包。


Duplicate Classes

对多个类加载器加载的类进行分析。

Leak Suspects

内存泄漏报告和系统概述


Top Components

列出内存用量超过堆总量1%的组件

内存分析工具-MAT(Memory Analyzer Tool)的更多相关文章

  1. Android 内存分析工具 MAT(Memory Analyzer Tool)

    如果使用DDMS确实发现了我们的程序中存在内存泄漏,那又如何定位到具体出现问题的代码片段,最终找到问题所在呢?如果从头到尾的分析代码逻辑,那肯定 会把人逼疯,特别是在维护别人写的代码的时候.这里介绍一 ...

  2. 内存分析工具MAT(Memory Analyzer Tool)从安装到使用

    一.安装 首先,你得有一个Eclipse(因为MAT是Eclipse的插件) 然后,你要在Eclipse上安装MAT,步骤如下: 1.点击Help,Install New Soft,就出现了以下Ins ...

  3. 【转】Eclipse MAT内存分析工具(Memory Analyzer Tool)

    Eclipse MAT内存分析工具(Memory Analyzer Tool) MAT内存分析工具# MAT是Memory Analyzer的简称,它是一款功能强大的Java堆内存分析器.可以用于查找 ...

  4. Eclipse MAT内存分析工具(Memory Analyzer Tool)

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

  5. 利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露

    转载:http://blog.csdn.net/wanghuiqi2008/article/details/50724676 一.开发环境: 操作系统:ubuntu 14.04 IDE:Eclipse ...

  6. [性能测试]:内存泄漏以及MAT(Memory Analyzer Tool)工具使用分析

    一.今天在查看服务器时候,发现内存使用率直接就到99%了, 二.用ps -uaxw查看一下,每个占用内存较多的进程情况: 三,挑出可疑的进程,生成dump文件: jmap -dump:format=b ...

  7. 使用MAT(Memory Analyzer Tool)工具分析dump文件--转

    原文地址:http://gao-xianglong.iteye.com/blog/2173140?utm_source=tuicool&utm_medium=referral 前言 生产环境中 ...

  8. MAT(Memory Analyzer Tool)工具入门介绍

    1.MAT是什么? MAT(Memory Analyzer Tool),一个基于Eclipse的内存分析工具,是一个快速.功能丰富的JAVA heap分析工具,它可以帮助我们查找内存泄漏和减少内存消耗 ...

  9. MAT(Memory Analyzer Tool)工具入门介绍(转)

    1.MAT是什么? MAT(Memory Analyzer Tool),一个基于Eclipse的内存分析工具,是一个快速.功能丰富的JAVA heap分析工具,它可以帮助我们查找内存泄漏和减少内存消耗 ...

随机推荐

  1. Docker环境安装与配置

    Docker 简介 Docker使用Go语言编写的 安装Docker推荐LInux内核在3.10上 在2.6内核下运行较卡(CentOS 7.X以上内核是3.10) Docker 安装 安装yum-u ...

  2. Xcode8.0 / OS X EI Capitan 10.11.6 提交报错90111

    改用新系统和新版xcode(都是正式版)后,提交App Store审核时报错: INFO ITMS-90111: "Beta Toolchain. 构建新的 App 和App 更新时,必须使 ...

  3. Integer包装类源码分析

    版权声明:本文为博主原创文章,转载请注明出处,欢迎交流学习! 今天上班的途中在手机里看到几道关于Integer拆装箱的小题目,正好有点时间翻看了一下Integer类的源码,加上自己的一点思考,决定写点 ...

  4. Shell-15--sed

  5. source insight 添加 python 支持

    从http://www.sourceinsight.com/public/languages/下载Python的配置文件Python.CLF 选择Options > Preferences,单击 ...

  6. 使用create-react-app 快速构建 React 开发环境以及react-router 4.x路由配置

    create-react-app 是来自于 Facebook,通过该命令我们无需配置就能快速构建 React 开发环境. create-react-app 自动创建的项目是基于 Webpack + E ...

  7. mint-ui Infinite scroll 重复加载、加载无效的原因及解决方案

    1.无限滚动的运用场景: 一般运用在列表展示,有分页.下拉加载更多的需求中. 2.代码分析 代码很简单,实现了列表分页,数据加载完之后显示数据状态 <template> <div c ...

  8. 关于小窗滑动,父级body也跟随滑动的解决方案

    需求:当前页面是信息列表,所以高度由内容自动填充, 所以页面可以上下滑动,加载更多, 但是下发物料一栏又为一个列表 所以做了一个弹窗框,因为是列表所以高度自然又是不可控的,所以给了一个最大高度,当超出 ...

  9. 【转】ASP.NET Core MVC 配置全局路由前缀

    本文地址:http://www.cnblogs.com/savorboard/p/dontnet-IApplicationModelConvention.html作者博客:Savorboard 前言 ...

  10. Android开发之漫漫长途 XIX——HTTP

    该文章是一个系列文章,是本人在Android开发的漫漫长途上的一点感想和记录,我会尽量按照先易后难的顺序进行编写该系列.该系列引用了<Android开发艺术探索>以及<深入理解And ...