说说内存分析工具 MAT 的基本用法

Eclipse 的 MAT(Memory Analyzer Tool) 是一个内存分析工具,它可以分析内存中的对象、以及对象在内存的占用大小等等丰富功能 。

1 加载堆存储文件

安装好 MAT 之后,双击打开进入主界面,接着点击 File → Open Heap Dump 打开 JVM 的堆存储文件。打开之后,就会让我们选择希望首次进入时的报告页,这里使用默认:

2 概览(Overview)

点击 “Overview” ,打开概览页签:

概览页签的 Details 内容区,可以看到堆的大小、类、对象以及类加载器的个数。

接下来是个饼图,直观地描述了 dump 中占用内存最大的对象的前几名分布情况。

还可以使用鼠标移动并点击饼图中的某一块,进行更多分析操作:

3 类实例数列表(Histogram)

这里展示了每个类所对应的实例数列表。这里的每一列都可以点击,修改其排序方式。

第一列是类名,第二列是这个类所创建的实例数。

这里重点说说 Shallow Heap 与 Retained Heap。

Shallow Heap 指的是当前对象所占用的内存大小。一般来说,每种数据类型都有一个标准,比如 Integer 占用 4 字节;Long 占用 8 字节。

要说 Retained Heap,就必须先说说 Retained set。Retained set 是对象 X 以及与对象 X 有关的一系列对象集合,当对象 X 被 GC 回收后,这个集合中的对象,也会被一并回收。 Retained Heap 就是当对象 X 被 GC 回收后,被释放的内存大小。

举个例子,假设 A 与 B 对象是垃圾回收的根,从 C 到 H 对象,它们之间的关系是这样的:

那么 Retained set 中就会存在以下关系:

对象 X 所对应的 Retained set
E E、G
C C、D、E、F、G、H
A,B A、B 、C、D、E、F、G、H

Histogram 默认会使用估算模式来计算 Retained Heap,因为只依赖于当前已检测到的集合中的对象数,所以会比精确计算快很多。

也可以点击 “计算器”图标,进行精确计算,不过很耗时,需要耐心等待哦O(∩_∩)O~

还可以使用正则表达式,过滤出我们想要看的 Class。比如,尝试在 ClassName 列的第一行输入 dbcp:

Histogram 可以按照不同的视角来展示该列表,默认是以类的形式,也可以按“超类”、按”类加载器”以及按“包”的形式,比如下例就是按“包”的形式来查找我们想要搜寻的类:

4 支配树(Dominator Tree)

Dominator Tree 中,显示的是 dump 中占用 Retained Heap 最多的大对象。

Dominator Tree 体现了对象实例之间的支配关系 。 在对象引用图中,如果所有指向对象 B 的路径都必须经过对象 A ,那么就认为对象 A 支配着对象 B。 如果对象 A 是离对象 B 最近的支配对象,那么对象 A 就是对象 B 的直接支配者 。 如果对象 A 支配着对象 B ,那么对象 A 的直接支配者也支配着对象 B。

左图表示对象之间的引用关系,右图表示左图所对应的支配树关系 。 对象 A 和 B 由 GC Roots 直接支配。因为在到对象 C 的路径中,即可以经过 A ,也可以经过 B ,所以对象 C 的直接支配者也是 GC Roots 。因此支配树关系图中的第一层是直连 A、B、C。 对象 F 与对象 D 相互引用,因为到对象 F 的所有路径必然经过对象 D ,所以,对象 D 是对象 F 的直接支配者 。 而到对象 D 的所有路径中,必然经过对象 C ,即使是从对象 F 到对象 D 的引用,从根节点出发,也是经过对象 C 的,所以,对象 D 的直接支配者为对象 C。 同理,对象 E 支配对象 G。 到达对象 H 的路径,即可以通过对象 D ,也可以通过对象 E ,因此对象 D 和 E 都不能直接支配对象 H ,而经过对象 C 既可以到达 D 也可以到达 E ,因此对象 C 为对象 H 的直接支配者 。

Dominator Tree 就是通过以上的逻辑判断,把对象之间的引用关系转换为对应的支配树关系的。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,064评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,606评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,011评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,550评论 1 269
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,465评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,919评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,428评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,075评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,208评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,185评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,191评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,914评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,482评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,585评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,825评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,194评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,703评论 2 339

推荐阅读更多精彩内容

  • 1.MAT简介:jvm内存溢出/内存泄漏问题分析定位神器 MAT 全称Eclipse Memory Analysi...
    极简架构阅读 22,279评论 1 20
  • 专业考题类型管理运行工作负责人一般作业考题内容选项A选项B选项C选项D选项E选项F正确答案 变电单选GYSZ本规程...
    小白兔去钓鱼阅读 8,963评论 0 13
  • 一、获取HPROF文件 HPROF文件是MAT能识别的文件,HPROF文件存储的是特定时间点,java进程的内存快...
    小村医阅读 1,641评论 0 2
  • MAT简介 MAT(Memory Analyzer Tool),一个基于Eclipse的内存分析工具,是一个快速、...
    This4U阅读 1,135评论 0 5
  • 最近频繁出差,每次总是忘记带一些东西,今天用导图做了一个物品规划清单,不做不知道,一做吓一跳,做这个清单也做了三个...
    李大鹏_365阅读 360评论 0 1