一、内存分配策略
1.1 指针碰撞
顺序分配,分配与未分配之间添加一个指针,每次分配时,指针往后移动需要的空间即可
优点:操作简单
缺点:要求堆空间要规整;多线程下效率不高
1.2 空闲列表
按需分配,需要一张表记录分配情况
优点:需要一个列表做存储
缺点:产生了空间碎片问题,大对象存入时会出现无连续空间问题
二、对象在堆中的存储布局
在HotSpot虚拟机里,对象在堆内存中的存储布局可以划分为三个部分:
2.1 对象头
2.1.1 Mark Word
存储对象自身的运行时数据:哈 希码(HashCode)、GC分代年龄、锁状态标志、线程持有的锁、偏向线程ID、偏向时间戳等。
使用Mark Word(一个有着动态定义的数据结构)做存储:
所占位数:32(64)位操作系统中是32(64)位;如对象未被同步锁锁定的状态下,Mark Word的32个比特存储空间中的25个比特用于存储对象哈希码,4个比特用于存储对象分代年龄,2个比特用于存储锁标志位,1个比特固定为0。在其他状态(轻量级锁定、重量级锁定、GC标记、可偏向)下对象的存储内容如表所示
<