对象创建始于new指令,JVM先加载类到方法区并生成Class对象;随后在堆中分配内存,采用指针碰撞或空闲列表策略,取决于垃圾回收器和内存整理情况;为保障线程安全,优先使用TLAB实现线程私有分配,不足时通过CAS重试保证原子性;对象内存布局由对象头、实例数据和对齐填充组成,包含哈希码、锁状态、字段值等信息,并按8字节对齐;最后设置对象头并执行构造函数完成初始化,整个过程由JVM高效管控。

Java对象在堆上的创建过程涉及多个步骤,包括类加载、内存分配、初始化等。整个过程由JVM控制,核心目标是高效、安全地为对象分配内存,并保证程序的正确执行。
类加载与new指令触发对象创建
当代码中执行new Object()时,JVM首先检查该类是否已被加载。如果尚未加载,先通过类加载器将.class文件加载到方法区,并生成对应的Class对象。类加载完成后,JVM识别new指令,准备在堆上为新对象分配内存。
堆中内存分配方式
JVM在堆中为对象分配空间主要有两种策略:
- 指针碰撞(Bump the Pointer):适用于堆内存规整的情况。所有已使用内存放在一边,空闲内存放在另一边。分配时只需移动指针即可。
- 空闲列表(Free List):适用于内存不连续的情况。JVM维护一个列表记录哪些内存块可用,分配时从中找出足够大的块给对象使用。
采用哪种方式取决于所使用的垃圾回收器和堆内存是否支持压缩整理。
立即学习“Java免费学习笔记(深入)”;
线程安全与分配优化
多线程环境下,多个线程同时创建对象可能导致内存分配冲突。JVM提供两种解决方案:
- TLAB(Thread Local Allocation Buffer):每个线程在Eden区预先分配一块私有内存区域。对象优先在TLAB中分配,避免竞争。当TLAB空间不足时,才进行同步分配。
- 若未启用TLAB或空间不够,则使用CAS(Compare and Swap)加失败重试机制保证原子性。
对象的内存布局
对象在堆中由三部分组成:
- 对象头(Header):包含哈希码、GC分代年龄、锁状态标志、线程持有的锁等信息。如果是数组,还包含数组长度。
- 实例数据(Instance Data):真正保存对象字段的值,按声明顺序排列,同时考虑虚拟机的字段对齐策略(如8字节对齐)。
- 对齐填充(Padding):并非必然存在,用于确保对象大小是8字节的整数倍,满足JVM内存对齐要求。
基本上就这些。对象从new指令开始,经历类加载、内存分配、设置对象头、执行构造函数等步骤,最终在堆中完成创建。整个过程由JVM精细管理,开发者无需手动干预,但理解其机制有助于写出更高效的代码。









