经典面试题 | 讲一下垃圾回收器都有哪些?
垃圾回收器有哪些?是一个高频的面试题,那本文就详细来解答这个问题。
因为不同的厂商(IBM、Oracle),实现的垃圾回收器各不相同,而本文要讨论的是 Oracle 的 HotSpot 虚拟机所使用的垃圾回收器。
常用垃圾回收器,如下图所示:
新生代回收器:Serial、ParNew、Parallel Scavenge
老年代回收器:Serial Old、Parallel Old、CMS
整堆回收器:G1
其中相互连线的垃圾回收器,表示可以相互搭配使用。
新生代 And 老生代
目前常用的商用垃圾收集器都使用的是分代垃圾回收方式。
分代垃圾回收器把内存分为:新生代(Young Generation)和老生代(Tenured Generation),如下图所示:
(图片来自fancydeepin)
默认情况下,新生代和老生代的内存比例是 1:2,该值可以通过 -XX:NewRatio
来设定。
新生代(Young Generation)
程序中的大部分对象都符合“朝生夕死”的特性,所以绝大数新创建的对象都会存放在新生代,除非是大对象会直接进入老生代。新生代采用的是复制算法,这样可以更高效的回收内存空间。
新生代有细分为:Eden、Form Survivor、To Survivor 三个区域,默认的比例是 8:1:1,可以通过 -XX:SurvivorRatio
来设定。
新生代垃圾回收的执行过程:
1、Eden 区 + From Survivor 区存活着的对象复制到 To Survivor 区;
2、清空 Eden 和 From Survivor 分区;
3、From Survivor 和 To Survivor 分区交换(From 变 To,To 变 From)。
老生代(Tenured Generation)
老生代垃圾回收的频率比新生代低,存放的主要对象是:
1、新生代对象经过 N 次 GC 晋升到老年代。
可以通过设置 -XX:MaxTenuringThreshold=5
来设置,默认值是 15 次。
2、大对象直接存储到老生代。
所谓的“大对象”指的是需要连续存储空间的对象,比如:数组。
当大对象在新生代存储不下的时候,就需要分配担保机制,把当前新生代的所有对象复制到老年代中,因为分配担保机制需要涉及大量的复制,会导致性能问题,所有最好的方案是直接把大对象存储到老生代中。
通过参数 -xx:PretrnureSizeThreshold
来设定大对象的值。
注意:该参数只有 Serial 和 ParNew 垃圾回收器有效。
Serial
Serial 最早的垃圾回收器,JDK 1.3.1 之前新生代唯一的垃圾回收器,使用的是单线程串行回收方式,在单 CPU 环境下性能较好,因为单线程执行不存在线程切换。
线程类型: 单线程
使用算法: 复制算法
指定收集器: -XX:+UseSerialGC
Serial Old
Serial 收集器的老年代版本,同样也是单线程的。它有一个实用的用途作为CMS收集器的备选预案,后面介绍CMS的时候会详细介绍。
线程类型: 单线程
使用算法: 标记-整理
指定收集器: -XX:+UseSerialGC
ParNew
ParNew 其实就是 Serial 的多线程版本,可以和 Serial 共用很多控制参数,比如:-XX:SurvivorRatio , ParNew 可以和 CMS 配合使用。
(注:图片来源于零壹技术栈)
线程类型: 多线程
使用算法: 复制
指定收集器: -XX:+UseParNewGC
Parallel Scavenge
Parallel 和 ParNew 收集器类似,也是多线程的,但 Parallel 是吞吐量优先的收集器,GC停顿时间的缩短是以吞吐量为代价的,比如收集 100MB 的内存,需要 10S 的时间,CMS 则会缩短为 7S 收集 50 MB 的内存,这样停顿的时间确实缩少了,但收集的频率变大了,吞吐量就变小了。
线程类型: 多线程
使用算法: 复制
指定收集器: -XX:+UseParallelGC
Parallel Old
Parallel Old 是 Parallel 的老生代版本,同样是吞吐量优先的收集器。
线程类型: 多线程
使用算法: 标记-整理
指定收集器: -XX:+UseParallelOldGC
CMS
CMS(Concurrent Mark Sweep)一种以获得最短停顿时间为目标的收集器,非常适用B/S系统。
使用 Serial Old 整理内存。
CMS 运行过程:
(注:图片来源于零壹技术栈)
1、初始标记
标记 GC Roots 直接关联的对象,需要 Stop The World 。
2、并发标记
从 GC Roots 开始对堆进行可达性分析,找出活对象。
3、重新标记
重新标记阶段为了修正并发期间由于用户进行运作导致的标记变动的那一部分对象的标记记录。这个阶段的停顿时间一般会比初始标记阶段稍长一些,但远比并发标记的时间短,也需要 Stop The World 。
4、并发清除
除垃圾对象。
CMS 缺点:
1、对 CPU 资源要求敏感。
CMS 回收器过分依赖于多线程环境,默认情况下,开启的线程数为(CPU 的数量 + 3)/ 4,当 CPU 数量少于 4 个时,CMS 对用户本身的操作的影响将会很大,因为要分出一半的运算能力去执行回收器线程。
2、CMS无法清除浮动垃圾。
浮动垃圾指的是CMS清除垃圾的时候,还有用户线程产生新的垃圾,这部分未被标记的垃圾叫做“浮动垃圾”,只能在下次 GC 的时候进行清除。
3、CMS 垃圾回收会产生大量空间碎片。
CMS 使用的是标记-清除算法,所有在垃圾回收的时候回产生大量的空间碎片。
注意:CMS 收集器中,当老生代中的内存使用超过一定的比例时,系统将会进行垃圾回收;当剩余内存不能满足程序运行要求时,系统将会出现 Concurrent Mode Failure,临时采用 Serial Old 算法进行清除,此时的性能将会降低。
线程类型: 多线程
使用算法: 标记-清除
指定收集器: -XX:+UseConcMarkSweepGC
G1
G1 GC 这是一种兼顾吞吐量和停顿时间的 GC 实现,是 JDK 9 以后的默认 GC 选项。G1 可以直观的设定停顿时间的目标,相比于 CMS GC,G1 未必能做到 CMS 在最好情况下的延时停顿,但是最差情况要好很多。
G1 GC 仍然存在着年代的概念,但是其内存结构并不是简单的条带式划分,而是类似棋盘的一个个 region。Region 之间是复制算法,但整体上实际可看作是标记 - 整理(Mark-Compact)算法,可以有效地避免内存碎片,尤其是当 Java 堆非常大的时候,G1 的优势更加明显。
G1 吞吐量和停顿表现都非常不错,并且仍然在不断地完善,与此同时 CMS 已经在 JDK 9 中被标记为废弃(deprecated),所以 G1 GC 值得深入掌握。
G1 运行过程:
1、初始标记
标记 GC Roots 直接关联的对象,需要 Stop The World 。
2、并发标记
从 GC Roots 开始对堆进行可达性分析,找出活对象。
3、重新标记
重新标记阶段为了修正并发期间由于用户进行运作导致的标记变动的那一部分对象的标记记录。这个阶段的停顿时间一般会比初始标记阶段稍长一些,但远比并发标记的时间短,也需要 Stop The World 。
4、筛选回收
首先对各个 Region 的回收价值和成本进行排序,根据用户所期望的 GC 停顿时间来制定回收计划。这个阶段可以与用户程序一起并发执行,但是因为只回收一部分 Region,时间是用户可控制的。
线程类型: 多线程
使用算法: 复制、标记-整理
指定收集器: -XX:+UseG1GC(JDK 7u4 版本后可用)
最后:本文欢迎任何形式的转载,如需开通白名单,请在评论区留下公众号ID即可。
参考
【End】
查看更多面试题内容,请访问《Java最常见200+面试题全解析》,它包含的模块有:
Java、JVM 最常见面试题解析
Spring、Spring MVC、MyBatis、Hibernate 面试题解析
MySQL、Redis 面试题解析
RabbitMQ、Kafka、Zookeeper 面试解析
微服务 Spring Boot、Spring Cloud 面试解析
扫描下面二维码付费阅读
关注下方二维码,订阅更多精彩内容。
转发朋友圈,是对我最大的支持。
经典面试题 | 讲一下垃圾回收器都有哪些?相关推荐
- java面试题jvm_经典面试题|讲一讲JVM的组成
经典面试题|讲一讲JVM的组成 发布时间:2019-04-10 09:01, 浏览次数:1456 , 标签: JVM JVM(Java 虚拟机)算是面试必问的问题的了,而但凡问 JVM 一定会问的第一 ...
- 经典面试题:聊一聊垃圾回收算法
关于垃圾回收算法的这道面试题,几乎是所有 3 年以上的 Java 面试中必问的题目,甚至有些好一点的公司会在校招时问到面试者.那么本文就系统的讲一下垃圾回收的算法,和 Hotspot 虚拟机执行垃圾回 ...
- 李洪强iOS经典面试题37-解释垃圾回收的原理
李洪强iOS经典面试题37-解释垃圾回收的原理 问题 我们知道,Android 手机通常使用 Java 来开发,而 Java 是使用垃圾回收这种内存管理方式. 那么,ARC 和垃圾回收对比,有什么优点 ...
- C#精髓【月儿原创】第一讲 使用垃圾回收器
说明:准备出一个系列,所谓精髓讲C#语言要点.这个系列没有先后顺序,不过尽量做到精.可能会不断增删整理,本系列最原始出处是csdn博客,谢谢关注. C#精髓 第一讲 使用垃圾回收器 作者:清清月儿 主 ...
- 经典面试题 | 讲一讲JVM的组成
来源:王磊的博客 JVM(Java 虚拟机)算是面试必问的问题的了,而但凡问 JVM 一定会问的第一个问题就是:讲一讲 JVM 的组成?那本文就注重讲一下 JVM 的组成. 首先来说 JVM 的组成分 ...
- 经典面试题|讲一讲JVM的组成
JVM(Java 虚拟机)算是面试必问的问题的了,而但凡问 JVM 一定会问的第一个问题就是:讲一讲 JVM 的组成?那本文就注重讲一下 JVM 的组成. 首先来说 JVM 的组成分为,整体组成部分和 ...
- 垃圾回收器都有哪些?
垃圾回收器有哪些?是一个高频的面试题,那本文就详细来解答这个问题. 因为不同的厂商(IBM.Oracle),实现的垃圾回收器各不相同,而本文要讨论的是 Oracle 的 HotSpot 虚拟机所使用的 ...
- jdk8默认垃圾回收器_JVM系列之经典垃圾回收器(上篇)
封面图 1.前言 随着 JDK 的不断更新,垃圾回收器的效率也越来越高.每一次 JDK 的更新,必然会包含有垃圾回收器的更新,截止目前,在最新的 JDK14 版本中,最新的垃圾回收器为 ZGC. 从垃 ...
- JVM系列之经典垃圾回收器
上篇:https://mp.weixin.qq.com/s/GVabLd4BAZGDBe9xL86k3w 1.前言 随着 JDK 的不断更新,垃圾回收器的效率也越来越高.每一次 JDK 的更新,必然会 ...
最新文章
- RabbitMQ在windows系统安装部署文档
- linux 管理mysql,Linux上MySQL的管理配置
- php渲染视图,Laravel 视图渲染:Blade 模板引擎
- GitHub:Python 强化学习实用指南
- 面试官:为什么要用 Spring?它到底解决了什么问题?
- java手机单机游戏_手机单机游戏推荐简介
- 腾讯程序员不寻常的三年
- ASU计算机科学专业大学排名,2013美国大学排名_计算机科学专业研究生排名
- A调用B方法,@Transactional事务失效情况
- 计算机考试office难还是c语言难,计算机二级考试c语言难不难
- java中13%(-3)_Java13版本特性【一文了解】
- 使用endnote自动批量生成毕业论文参考文献
- 循环调用scrapy框架出现的问题:twisted.internet.error.ReactorNotRestartable,解决方法
- 传世私服服务器列表不显示,关于传世私服的人物名字显示设置详解
- Linux中的文本流
- #Ubuntu 历程# guest账户管理
- 赵志勇记录下的算法+程序
- 【论文阅读】Automatic Updating of Land Cover Maps in Rapidly Urbanizing Region
- php sequelize,关于javascript:eggjs-sequelize-的常用方法总结
- SWPU NSS新生赛校外通道(部分WP)