Shallow heap & Retained heap

痛定思痛。 2022-04-01 14:46 315阅读 0赞

所有包含Heap Profling功能的工具(MAT, Yourkit, JProfiler, TPTP等)都会使用到两个名词,一个是Shallow Size,另一个是 Retained Size.
这是两个在平时不太常见的名词,本文会对这两个名词做一个详细的解释。

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

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

看图理解Retained Size
在这里插入图片描述

上图中,GC Roots直接引用了A和B两个对象。

A对象的Retained Size=A对象的Shallow Size
B对象的Retained Size=B对象的Shallow Size + C对象的Shallow Size

这里不包括D对象,因为D对象被GC Roots直接引用。
如果GC Roots不引用D对象呢?
在这里插入图片描述
此时,
B对象的Retained Size=B对象的Shallow Size + C对象的Shallow Size + D对象的Shallow Size

转载自:https://bjyzxxds.iteye.com/blog/1532937

发表评论

表情:
评论列表 (有 0 条评论,315人围观)

还没有评论,来说两句吧...

相关阅读

    相关 heap_sort

    排序是利用堆来进行排序。 堆的定义:n个元素的序列(a1,a2...an)当且仅当满足下面关系时,称为堆。 (a(i)<=a(2\*i) && a(i)<=a(2\*...

    相关 Heap

    Heap 译为"堆"是Java虚拟机JVM的内存数据区。Heap 的管理很复杂,每次分配不定长的内存空间,专门用来保存对象的实例。在Heap 中分配一定的内存来保存对象实例,实

    相关 STL:heap

    写在前面 > STL:heap 主要内容 > heap是什么 heap并不是STL的容器,是以算法的方式出现的。扮演priority\_queue的幕后英雄。

    相关 Java heap space

    摘要: > 因为项目涉及到的数据较,对象较多,所以在执行时遇到了这个错误 > > 通过搜索,应该不能找到这种错误出现的原因,伴随这个错误的一般还有如下错误: > >