JVM垃圾收集器的搭配
来源:互联网 发布:mac磁盘工具无法抹掉 编辑:程序博客网 时间:2024/06/05 02:37
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收集器理论上可以达到更短的停顿时间,并且不分新生代老年代,但尚未在大规模应用中经受过考验,若个人使用追求更短的停顿时间可以尝试,不建议在生产环境中使用
- JVM垃圾收集器的搭配
- JVM的垃圾收集器
- JVM的垃圾收集器
- JVM的垃圾收集器
- JVM的垃圾收集器
- JVM的垃圾收集
- JVM垃圾收集器
- JVM垃圾收集器
- JVM-垃圾收集器
- JVM垃圾收集器
- JVM垃圾收集器
- jvm 垃圾收集器
- 【JVM】垃圾收集器
- JVM 垃圾收集器
- JVM-垃圾收集器
- JVM > 垃圾收集器
- JVM--垃圾收集器
- JVM垃圾收集器
- java中ThreadLocal类的使用
- spring整合hibernate错误总结
- 教你怎么上传本地代码到github
- 使用adb命令进行无线安装调试apk
- 表单_get和post提交的区别、乱码
- JVM垃圾收集器的搭配
- for循环异步调用接口,怎样判断数据已经返回完成?
- 大话数据结构 code 第四章 02两栈共享空间_DoubleStack
- 【codevs1191】数轴染色 并查集
- [刷题]2017百度之星资格赛
- Pagination分页插件
- 多线程在微服务API统计和健康检查中的使用
- 双目相机--双目视差与深度距离关系推导详解
- 养成这6个编程好习惯,助你减少90%BUG