深入理解JVM - 内存分配策略

本文深入探讨了Java垃圾回收机制中的对象分配策略,包括对象在Eden区的优先分配、大对象直接进入老年代的条件及影响,以及长期存活对象晋升至老年代的过程。文章还解析了动态对象年龄判定和空间分配担保机制,揭示了如何优化内存管理和减少FullGC的发生。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对象优先在Eden分配

对象优先在Eden分配,如果说Eden内存空间不足,就会发生Minor GC

大对象直接进入老年代

大对象:需要大量连续内存空间的Java对象,比如:很长的字符串和大型数组。

大对象带来的副作用:

  1. 当没有足够的连续空间来存放大对象的时候,就需要提前出发一次Full GC
  2. 在内存回收过程中,会进行大量的内存复制

-XX:PretenureSizeThreshold参数 ,大于这个参数数量直接的对象直接在老年代分配,缺省为0 ,表示绝不会直接分配在老年代。

长期存活的对象将进入老年代

长期存活的对象将进入老年代,默认15岁,可以通过-XX:MaxTenuringThreshold调整。

动态对象年龄判定

为了能更好地适应不同程序的内存状况,虚拟机并不是永远地要求对象的年龄必须达到了MaxTenuringThreshold才能晋升老年代,如果在Survivor空间中相同年龄所有对象大小的总和大于Survivor空间的一半,年龄大于或等于该年龄的对象就可以直接进入老年代,无须等到MaxTenuringThreshold的年龄。

空间分配担保

新生代中有大量的对象存活,survivor空间不够,当出现大量对象在MinorGC后仍然存活的情况(最极端的情况就是内存回收后新生代中所有对象都存活),就需要老年代进行分配担保,把Survivor无法容纳的对象直接进入老年代。

只有老年代的最大可用连续空间大于新生代所有对象的总和或者老年代最大连续空间比历次晋升的平均值大,就进行Minor GC,否则FullGC。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值