JVM(HotSpot):GC之分代回收机制及相关常用参数

一、内存区域说明

在这里插入图片描述
如图所示,分代回收机制,将JVM内存分为老年代和新生代
其中,新生代又分成三部分:Eden区,Survivor From区,Survivor To区


它们的大小比例关系如下:
在这里插入图片描述
老年代:2/3的堆空间
年轻代:1/3的堆空间

Eden区:8/10 的年轻代
Survivor0: 1/10 的年轻代
Survivor1:1/10 的年轻代


新生代GC: Minor GC
老年代GC:Full GC

二、对象存储的过程说明

1、新创建的对象,首先,是存入Eden区。
在这里插入图片描述
2、当Eden区无法存放新的对象时,会触发一次Minor GC(复制算法)。
会根据可达性分析,将垃圾对象标记出来,然后,将存活对象复制到To区域。
并给存活对象标记一个年龄。

Minor GC时,会引发Stop The World,就是暂停用户线程,等Minor GC执行结束后,再恢复用户线程

注意:新生代对象的特点,存活对象占比较少。
在这里插入图片描述
3、交换FromTo区域的标记。
在这里插入图片描述
4、继续生产新对象,直到触发第2次Minor GC
依然根据可达性分析算法,标记整个新生代区域中的垃圾对象。
Eden区和To区,存活的对象复制到From区,并将对象年龄+1
在这里插入图片描述
5、依次循环上述步骤,发生Minor GC,并给存活的对象年龄+1,当对象年龄达到15(4bit)时,会将Survivor区中的该对象复制到老年代中。
在这里插入图片描述
6、当老年代区的空间放不下的时候,会先触发Minor GC,如果空间仍然不够,才触发Full GC
STW的时间较长。
在这里插入图片描述
7、如果,Full GC后,空间依然不够,就发生OOM错误。
8、当创建一个大对象时,如果它的大小直接超出了新生代的范围,那么,会直接存入老年代,不会触发Minor GC,如果老年代也存不下,则发生一次Full GC,如果还放不下,则会直接OOM
9、Thread线程里面发生OOM,不会导致main线程终止。
10、每次Full GC前,都会发生一次Minor GC

三、常用GC参数

在这里插入图片描述
参考:
Java GC堆和jvm参数设置
java中GC的常用参数设置
运行JVM的GC参数是什么?
java–jvm GC-常用参数配置

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值