JVM垃圾收集器的搭配

JDK1.5及之前的JDK上:


如果jvm运行在client上:
1.若为单核CPU:新生代使用Serial,老年代使用Serial Old

2.若为多核CPU:新生代使用ParNew,老年代使用CMS(硬件比较高级的情况下,如果普通的双核cpu甚至不如serial+serial old)

如果jvm运行在server上:

1.若注重吞吐量(比如执行的多为后台计算这种任务):新生代使用Parallel Scavenge收集器,老年代使用Serial Old收集器

2.若注重交互和响应时间:

  
(1)单核:新生代使用serial,老年代使用CMS

(2)多核cpu/多cpu:新生代使用ParNew,老年代使用CMS

JDK1.6之后发布的Parallel Old收集器与Parallel收集器一起使用可以达到较好的吞吐量,其余同jdk1.5及之前的版本


垃圾收集器特征整理:

1.Serial收集器:Serial收集器是一个单线程的新生代收集器,到目前仍然是client模式下的默认新生代收集器

2.Serial Old收集器:Serial Old收集器是单线程的老年代收集器,目前也是client模式下的默认老年代收集器

3.ParNew收集器:Par New收集器是Serial的多线程版本,除了单线程收集器Serial外,目前只有该收集器可以与CMS收集器一起工作

4.Parallel Scavenge收集器:Parallel Scavenge收集器是一个多线程的新生代收集器,它与ParNew的不同之处在于该收集器更注重吞吐量而不是更短的停顿时间

5.Parallel Old收集器:该收集器是Parallel Scavenge收集器的老年代版本,在jdk1.6之后才提供,用以代替jdk1.5及之前的Parallen Scavenge+Serial Old的尴尬组合(Parallel Scavenge收集器无法与CMS一起工作)

6.CMS收集器:jdk1.5时发布的一个老年代收集器,因其停顿时间很短,很符合强交互应用的要求,但只能与Serial收集器、ParNew收集器搭配工作,不能与Parallel Scavenge一起工作

7.再往后的G1收集器理论上可以达到更短的停顿时间,并且不分新生代老年代,但尚未在大规模应用中经受过考验,若个人使用追求更短的停顿时间可以尝试,不建议在生产环境中使用

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值