Java虚拟机内存分配策略
1.JVM内存分配分区Java的内存简单分为堆内存和非对内存其中堆内存又可以分为新生代和老年代新生代分为1个Eden区和2个Survivor区,如下图:2.JVM垃圾回收种类分为2种,MinorGC和FullGC.MinorGC针对新生代的内存回收,时间较短,经常发生。FullGC针对老年代的回收,通常伴随MinorGC,耗费时间较久,较少发生。2.JVM内存分配策略(1)先在E
1.JVM内存分配分区
Java的内存简单分为堆内存和非堆内存
其中堆内存又可以分为新生代和老年代
新生代分为1个Eden区和2个Survivor区,如下图:
2.JVM垃圾回收种类
分为2种,MinorGC和FullGC.
MinorGC针对新生代的内存回收,时间较短,经常发生。
FullGC针对老年代的回收,通常伴随MinorGC,耗费时间较久,较少发生。
3.JVM内存分配策略
(1)先在Eden区分配,如果不够分配的话,发生MinorGC。
(2)进行MinorGC时,会把Eden中有在使用的对象放到其中一个Survivor中。如果Survivor中放不下,则会进入老年代。
(3)每次进行MinorGC时,在Survivor中存活的对象会增加1岁,默认超过15岁的对象(MaxTenuringThreshold),会进入老年代。
(4)JVM的参数有一个叫PretenureSizeThreshold,大小超过这个值的对象会直接进入老年代。
4.垃圾回收器种类
Serial/Serial Old
(1)适合单个CPU
(2)Serial采用复制算法,适合新生代
(3)Serial Old采用标记-整理算法,适合老年代
ParNew
(1)多线程,并行
Parallel Scavenge
(1)适合新生代,并行
(2)适合后台运算的任务,追求的是吞吐量,支持参数自适应
Parallel Old
(1)适合老年代,与Parallel Scavenge搭配使用
CMS(Consurrent Mark Sweep)
(1)追求短停顿,采用标记-清除算法
(2)无法处理浮动垃圾
(3)要求CPU较多
G1
(1)并行+并发
(2)分代采用不同算法进行收集
(3)标记整理+复制算法
(4)可预测停顿时间
更多推荐
所有评论(0)