硬核干货——《中小企业 AI 实战指南》免费下载! 了解详情
写点什么

Oracle 提议将 G1 作为 Java 9 的默认垃圾收集器

  • 2015-06-16
  • 本文字数:810 字

    阅读完需:约 3 分钟

Oracle 正在考虑将 JEP 248 包含到 Java 9 的 JEP 列表中,即在服务器配置中将 G1 作为默认垃圾收集器。该决定在 Java 社区引发了一些争论,许多人都认为并发标记和扫描(CMS)收集器可能更合适。

如果该决定付诸实施,那么 G1 将取代并行垃圾收集器成为服务器配置的默认选项。正如 Oracle 在内存管理白皮书中描述的那样,并行垃圾收集器的设计初衷是,通过不常发生(但可能时间比较长)的 Stop-The-World(STW)中断最大化应用程序吞吐量。并行垃圾收集器将消耗的总计算时间最小化,长远来看,其破坏性更小,因此可以提供更好的整体性能。该收集器非常适合对响应时间要求不高的应用程序,比如,批处理。

另一方面,正如前 G1 性能负责人 Monica Beckwith先前在 InfoQ 上阐述的那样,Garbage First(G1)的设计初衷是,以更高的计算成本为代价最小化 STW 中断时间。G1 更适合于低延迟应用程序,如 Web 服务器,这也体现了 Stefan Johansson 在 JEP 中所描述的动机:

通常来说,限制 GC 中断时间比最大化吞吐量更重要。对大部分用户而言,与面向吞吐量的收集器相比(如并行垃圾收集器),切换到中断时间短的垃圾收集器(如 G1),可以获得更好的整体体验。

这里出现了争议。HotSpot 因为同样的目的引入了 CMS,而实际上,按照 Oracle 的描述,CMS“设计用于更希望缩短垃圾收集中断时间的应用程序,以及在运行时可以与垃圾收集器共享处理器资源的应用程序”。许多公开的基准测试都表明,在内存占用相对较小的应用程序中,CMS 的性能往往要胜过 G1,这与 Oracle 对 G1 的描述一致,即 G1 适用于堆大小为 6GB 及以上的服务器应用程序。

在最近的一次交流中,性能专家 Kirk Pepperdine 特别指出,谷歌已经向 CMS 贡献了若干改进,但它们从没有出现在 HotSpot 中。他还补充说,虽然长远看 G1 可能是更好的选择,但 Oracle 的设计方案已经剥夺了社区从 CMS 获得更好体验的权力。

查看英文原文: Oracle Proposes G1 as the Default Garbage Collector for Java 9

2015-06-16 22:179627
用户头像

发布了 1008 篇内容, 共 436.5 次阅读, 收获喜欢 346 次。

关注

评论

发布
暂无评论
发现更多内容

React的useLayoutEffect和useEffect执行时机有什么不同

beifeng1996

React

使用less/css 动态的切换主题色实现换肤功能

默默的成长

前端 Vue 3 10月月更

页面中元素的吸顶

默默的成长

前端 Vue 3 10月月更

React循环DOM时为什么需要添加key

beifeng1996

React

linux下驱动开发_红外线解码驱动

DS小龙哥

10月月更

嵌入式Linux下移植MT7601无线WIFI(网卡)驱动

DS小龙哥

10月月更

2022昇腾AI创新大赛16地区域决赛圆满落幕 32支队伍角逐全国冠军

极客天地

React源码分析(三):useState,useReducer

goClient1992

React

Java三大特性(三)—多态

共饮一杯无

Java 多态 10月月更

PriorityQueue 源码解析(四)

知识浅谈

Queue 10月月更

new Vue的时候到底做了什么

bb_xiaxia1998

Vue

vivo平台化实践探索之旅-平台产品系列01

vivo互联网技术

平台化 系统平台化

NFT链游系统开发丨Alien Worlds异形世界链游系统开发成熟技术(Demo)

I8O28578624

react源码中的生命周期和事件系统

flyzz177

React

页面中元素的锚点定位

默默的成长

前端 Vue 3 10月月更

React源码分析(二)渲染机制

goClient1992

React

pandas如何读写源数据

芥末拌个饭吧

pandas python 3.5+ 10月月更

深入浅出防抖与节流函数

CoderBin

JavaScript 面试 前端 防抖节流 10月月更

React面试八股文(第一期)

beifeng1996

React

滴滴前端二面vue相关面试题

bb_xiaxia1998

Vue

SparkSQL on K8s 在网易传媒的落地实践

网易数帆

大数据 spark Kubernetes Kyuubi 企业号十月 PK 榜

你真的了解redis持久化机制AOF吗?

芥末拌个饭吧

redis 后端 10月月更

你了解Redis RDB快照吗

芥末拌个饭吧

redis 后端 10月月更

Vue的computed和watch的区别是什么?

bb_xiaxia1998

Vue

从react源码看hooks的原理

flyzz177

React

C++ | bool变量值在程序运行过程中自动篡改问题解决

中国好公民st

c++ 变量 10月月更

最大为 N 的数字组合

掘金安东尼

算法 10月月更

算法基础(六)| 双指针算法及模板应用

timerring

算法 双指针 10月月更

软件测试 | 测试开发 | Cypress 强大全新的 Web UI 测试框架应用尝鲜

测吧(北京)科技有限公司

测试

软件测试 | 测试开发 | 一文搞定 Appium 环境配置

测吧(北京)科技有限公司

测试

华为云从入门到实战 | 云容器服务

TiAmo

华为 华为云 云开发 10月月更

Oracle提议将G1作为Java 9的默认垃圾收集器_Java_Abraham Marín Pérez_InfoQ精选文章