jvm对象的内存分布

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/jm19920911/article/details/79168020

对象的内存分布分为3部分:对象头,实例数据,对齐填充

1 对象头
对象头包括两部分:一部分是用于存储对象自身的运行时数据,官方叫做mark word。mark word中的数据包括:哈希码,GC分代年龄,锁状态标志,线程持有的锁,偏向线程id,偏向时间戳等。
另一部分是类型指针,虚拟机通过这个指针确定这个对象是哪个类的实例。如果对象是java数组,对象头必须有记录数组长度的数据。因为jvm可以通过普通java对象的元数据确定java对象的大小,但是从数组的元数据无法确认数组的大小

2 实例数据
实例数据是对象存储的有效数据。存储顺序会受到jvm分配策略和字段 在java源码中定义顺序的影响

3 对齐补充
对齐补充不是必需的,仅仅是占位符的作用。HotSpot VM的自动内存管理系统要求对象的起始地址必须是8字节的整倍数,即对象的大小必须是8字节的整倍数,不够整倍数就用这部分补充

摘抄总结自《深入理解java虚拟机》

猜你喜欢

转载自blog.csdn.net/jm19920911/article/details/79168020