JVM中深堆和浅堆的认识是怎么样的

发布时间:2021-10-23 16:14:16 作者:柒染
来源:亿速云 阅读:162

JVM中深堆和浅堆的认识是怎么样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

一、概念

我们先给出概念,然后再分析。

(1)浅堆表示一个java对象结构所占用内存的大小,这个java对象内部包含了三部分数据:对象头、实例数据和对齐填充。

(2)深堆表示一个java对象被 GC 回收后,可以真实释放的内存大小。

如果你有点疑惑,没关系。对上面出现的那些名词我们一个一个来解释。

1、对象头

一个对象分为三部分:对象头、实例数据、对齐填充。对象头又包含了两部分:标记部分和原始对象引用。

(1)标记部分:包括 hashcode、gc 分代年龄、锁状态标志、线程持有锁、偏向线程锁id,偏向时间戳,这一部分在32位机器上为 4 byte,64 位机器上为 8byte,一般来说我们的机器都是64位,所以现在默认指的是8个字节。

(2)原始对象引用是对象的指针,通过这个指针找到对象的实例,该数据可以压缩,32 位机器上为 4 byte,64位机器上为 8byte,jdk8默认开启压缩,大小为 4byte。

所以我们可以看到:一个java对象的对象头大小,没压缩的时候是16字节,压缩时候是12个字节。

2、实例数据

指的就是我们的java对象实例。这个很容易理解。

3、对齐填充

对齐填充要追根其根源,其实是到了计算机系统结构的学科。我在大学的时候学到了对齐填充,和这里是一样的道理。java中的对象都是以8个字节为单位对齐,所以每一个java对象的大小都是8的整数倍。

4、保留集

对象A能直接或者是间接访问其他的对象,这些对象集合起来就是A的保留集。当进行垃圾回收的时候,不仅回收A,也会回收保留集中所有的对象。

现在我们理解了这些基本的概念,再回过头来好好地看看,深堆和浅堆到底是什么?

浅堆指对象本身占用的内存,不包括其内部引用对象的大小。一个对象的深堆指只能通过该对象访问到的(直接或间接)所有对象的浅堆之和,即对象被回收后,可以释放的真实空间。在《实战java虚拟机》中,使用了一个案例,在这里引用一下:

JVM中深堆和浅堆的认识是怎么样的

A引用了对象C,D,对象B引用了对象C,E。

对象A引用了C和D,对象B引用了C和E。那么对象A的浅堆大小只是A本身,不含C和D,而A的实际大小为A、C、D三者之和。

而A的深堆大小为A与D之和,由于对象C还可以通过对象B访问到,因此不在对象A的深堆范围内。

我们再举一个例子来分析:1到100,被3整除的数可以送给对象A,被5整除的可以送给对象B。那么在程序退出时候,进行垃圾回收,此时对象A的的深堆肯定小于33,对象B的深堆肯定小于20,这是因为存在像15、30这样的数,既可以被3整除也可以被5整除,属于三不管对象。

代码就不再演示了,最后的结果还是使用MAT工具进行分析一下。

看完上述内容,你们掌握JVM中深堆和浅堆的认识是怎么样的的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

推荐阅读:
  1. 堆的性质是什么?怎么实现堆?
  2. 堆的简单应用

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

jvm

上一篇:如何使用Linux命令

下一篇:select、poll、epoll的区别有哪些

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》