1. 降低Minor GC频率
- Minor GC的时间分为两部分:扫描新生代和复制存活对象时间。
- 如果堆中短期的对象很多,扩容新生代的大小(虽然会增加扫描新生代的时间,但同时也会缩短复制对象的时间,因为减少了存回对象的数量。对于老年代来说,进行Major,甚至是Full GC来说,所需要的时间也会减少。
PS:扫描对象成本明显低于复制存活对象的成本)。
- 如果堆中长期存活的对象很多,则不应该增加新生代的大小,因为会增加Minor GC的时间(扫描和复制存活对象的时间,都不会减少)。
2. 降低Full GC频率
2.1 减少大对象的创建:
- 会超过所设置的大对象大小的阈值,直接进入老年代;
- 即使没有超过所设置的大对象大小的阈值,在新生代空间有限的情况下,根据空间分配担保也会有大几率被分配到老年代。
2.2 增大堆内空间设置
- 初始化堆内存和最大堆内存大小相同,也可以降低Full GC的频率。也会减少内存自动扩容、自动降容的成本。
3. 选择适当的GC回收器
对单次操作的响应时间有优先的要求,可以选择CMS和G1收集器堆系统吞吐量有优先的要求,可以选择Parallel Scavenge收集器。