Java8中GC收集器详解

新生代默认垃圾回收算法:标记复制          

老年代默认回收算法:标记整理

Minor GC和Full GC

Minor GC只针对新生代,触发条件:当Eden区满时,触发Minor GC。

Full GC包含新生代和老年代,触发条件:

(1)调用System.gc时,系统建议执行Full GC,但是不必然执行

(2)老年代空间不足

(3)方法区空间不足

(4)通过Minor GC后进入老年代的平均大小大于老年代的可用内存

(5)由Eden区、From Space区向To Space区复制时,对象大小大于To Space可用内存,则把该对象转存到老年代,且老年代的可用内存小于该对象大小。

接下里我们需要查看Java8默认的GC收集器:

查看Java8默认的GC收集器

java -XX:+PrintCommandLineFlags -version

结果如下图:

-XX:+UseParallelGC实际上是Parallel Scavenge (新生代)+ Parallel Old(老年代)

查看GC详情

java -XX:+PrintGCDetails -version

结果如下 

 下面我们来讲一下GC收集器

新生代:

1.serial收集器

单线程,工作时必须暂停其他工作线程。多用于client机器上,使用复制算法
2、ParNew收集器

serial收集器的多线程版本,server模式下虚拟机首选的新生代收集器。复制算法

3、Parallel Scavenge收集器

复制算法,可控制吞吐量的收集器。吞吐量即有效运行时间。

老年代:

4、Serial Old收集器

serial的老年代版本,使用整理算法。

5、Parallel Old收集器
第三种收集器的老年代版本,多线程,标记整理
6、CMS收集器
目标是最短回收停顿时间。

7、G1收集器

基本思想是化整为零,将堆分为多个Region,优先收集回收价值最大的Region

垃圾回收器的选择策略:

1、单CPU或者小内存,单机程序 — -XX:+UseSerialGC

2、多CPU,需要大吞吐量,如后台计算型应用

-XX:+UseParallelGC + -XX:+UseParallelOldGC

3、多CPU,追求低停顿时间,快速响应如互联网应用

-XX:+UseParNewGC + -XX:+UseConcMarkSweepGC

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值