十大垃圾回收器详解

news/2024/11/30 6:55:04/

十大垃圾回收器详解
JVM调优的第一要义就是重启,但是注意这是不优雅的方式但是管用。
Serial:回收垃圾时采用单线程运行机制就像是一个房间只能有一个人进行打扫如果空间很小的情况下可以使用Serial进行垃圾回收但是当空间很大时那个垃圾回收的速度将会很慢有可能造成卡顿,当工作线程将内存占满后垃圾回收器会停止工作线程的产生即进入到STW等待时间中进行垃圾回收等待,当Serial将内存中无用的对象进行回收完毕后才允许工作线程继续进行工作,Serial存在于年轻代中主要用Copying拷贝算法进行垃圾回收。
图解:
在这里插入图片描述

Serial Old :主要意义与Serial的意义相同,只不过此垃圾回收器用在老年代中主要采用标记清除算法或者标记压缩算法进行。
在这里插入图片描述

ParallelScavenge(PS):此垃圾回收器为多线程回收机制,适用于内存比较大的时候,比如几个G的内存时可用如果再大那么也会造成STW时间过长,当内存满了时停止工作线程,然后让多个线程进行垃圾回收,多线程就像是多个人同时在一个区域中进行垃圾清理。使用于新生代中既用到的算法为Copying拷贝算法垃圾回收速度快。
图解:并行多线程
在jdk1.8后自己没有设置过默认使用的就是ps和po
在这里插入图片描述

Parallel Old:此垃圾回收器和上面的PS机制相同只不过PS是用在新生代中,PO是用在老年代中,所用算法为标记清除算法或者标记压缩算法。
在这里插入图片描述
ParNew:此垃圾回收器就是一个翻版的PS垃圾回收器,主要是用来配合CMS垃圾回收器进行使用的。ParNew主要用于新生代中,也是用STW时间多线程清理垃圾,采用拷贝算法。
在这里插入图片描述

CMS:CMS是老年代垃圾收集器,在收集过程中可以与用户线程并发操作。它可以与Serial收集器和Parallel New收集器搭配使用。CMS牺牲了系统的吞吐量来追求收集速度,适合追求垃圾收集速度的服务器上。可以通过JVM启动参数:-XX:+UseConcMarkSweepGC来开启CMS。
CMS 处理过程有七个步骤:
初始标记(CMS-initial-mark) ,会导致stw,只找到最根上的对象;
并发标记(CMS-concurrent-mark),与用户线程同时运行;
预清理(CMS-concurrent-preclean),与用户线程同时运行;
可被终止的预清理(CMS-concurrent-abortable-preclean) 与用户线程同时运行;
重新标记(CMS-remark) ,会导致swt;
并发清除(CMS-concurrent-sweep),与用户线程同时运行;
并发重置状态等待下次CMS的触发(CMS-concurrent-reset),与用户线程同时运行;
在这里插入图片描述
如何找到误标和漏标的方法
三色标记法:
1.白色代表未被标记的对象
2.灰色代表自身被标记,成员变量未被标记的对象
3.黑色代表自身和成员变量均被标记完成
在这里插入图片描述
CMS会产生浮动垃圾问题

G1:
并行与并发:G1能充分利用多CPU、多核环境下的硬件优势,使用多个CPU来缩短Stop-The-World停顿时间。部分收集器原本需要停顿Java线程来执行GC动作,G1收集器仍然可以通过并发的方式让Java程序继续运行。
分代收集:G1能够独自管理整个Java堆,并且采用不同的方式去处理新创建的对象和已经存活了一段时间、熬过多次GC的旧对象以获取更好的收集效果。
空间整合:G1运作期间不会产生空间碎片,收集后能提供规整的可用内存。
可预测的停顿:G1除了追求低停顿外,还能建立可预测的停顿时间模型。能让使用者明确指定在一个长度为M毫秒的时间段内,消耗在垃圾收集上的时间不得超过N毫秒。
G1为什么能建立可预测的停顿时间模型?
因为它有计划的避免在整个Java堆中进行全区域的垃圾收集。G1跟踪各个Region里面的垃圾堆积的大小,在后台维护一个优先列表,每次根据允许的收集时间,优先回收价值最大的Region。这样就保证了在有限的时间内可以获取尽可能高的收集效率。
G1与其他收集器的区别:
其他收集器的工作范围是整个新生代或者老年代、G1收集器的工作范围是整个Java堆。在使用G1收集器时,它将整个Java堆划分为多个大小相等的独立区域(Region)。虽然也保留了新生代、老年代的概念,但新生代和老年代不再是相互隔离的,他们都是一部分Region(不需要连续)的集合。
G1收集器存在的问题:
Region不可能是孤立的,分配在Region中的对象可以与Java堆中的任意对象发生引用关系。在采用可达性分析算法来判断对象是否存活时,得扫描整个Java堆才能保证准确性。其他收集器也存在这种问题(G1更加突出而已)。会导致Minor GC效率下降。
G1收集器是如何解决上述问题的?
采用Remembered Set来避免整堆扫描。G1中每个Region都有一个与之对应的Remembered Set,虚拟机发现程序在对Reference类型进行写操作时,会产生一个Write Barrier暂时中断写操作,检查Reference引用对象是否处于多个Region中(即检查老年代中是否引用了新生代中的对象),如果是,便通过CardTable把相关引用信息记录到被引用对象所属的Region的Remembered Set中。当进行内存回收时,在GC根节点的枚举范围中加入Remembered Set即可保证不对全堆进行扫描也不会有遗漏。
如果不计算维护 Remembered Set 的操作,G1收集器大致可分为如下步骤:
初始标记:仅标记GC Roots能直接到的对象,并且修改TAMS(Next Top at Mark Start)的值,让下一阶段用户程序并发运行时,能在正确可用的Region中创建新对象。(需要线程停顿,但耗时很短。)
并发标记:从GC Roots开始对堆中对象进行可达性分析,找出存活对象。(耗时较长,但可与用户程序并发执行)
最终标记:为了修正在并发标记期间因用户程序执行而导致标记产生变化的那一部分标记记录。且对象的变化记录在线程Remembered Set  Logs里面,把Remembered Set  Logs里面的数据合并到Remembered Set中。(需要线程停顿,但可并行执行。)
筛选回收:对各个Region的回收价值和成本进行排序,根据用户所期望的GC停顿时间来制定回收计划。(可并发执行)
在这里插入图片描述


http://www.ppmy.cn/news/257294.html

相关文章

几种垃圾回收器

垃圾回收器分类 按线程分: 1.串行垃圾回收器。 2.并行垃圾回收器 按工作模式分: 1.并发式垃圾回收器 2.独占式垃圾回收器:GC时STW。 按碎片处理分: 1.压缩式垃圾回收器:压缩整理,清理碎片 2.非压缩…

垃圾回收器(GC)

目录 垃圾回收 概述 垃圾回收机制 垃圾回收标记阶段 Finaliztion机制 垃圾回收阶段算法 System.gc()与STW 垃圾回收器 CMS G1回收算法 查看 JVM 垃圾回收器设置垃圾回收器 垃圾回收 概述 垃圾回收功能是java中支持的功能,在其他的语言中也会存在自动的垃圾回收的功能…

五、垃圾回收器

一、串行搜集器 Serial收集器 同一时间只有一个CPU执行垃圾回收,此时应用程序暂停,直到垃圾回收完成;最古老的搜集器,最稳定;单线程没有线程间交互,回收效率高;当回收的内存很大时会造成长时间停…

常见垃圾回收器

CMS和G1是最重要的 总结: CMS:追求最短的停顿时间,并行的,垃圾回收线程可以和用户线程同时执行(只有初始标记阶段需要暂停用户线程,其他阶段不需要暂停用户线程) 采用三色标记法 G1:HotSpot 开发团队赋予它的使命…

垃圾处理器分类

萌新小白看完JVM垃圾处理器的笔记,只是大概的描述一下垃圾处理器的几种,以及使用到的算法、运行过程和其缺陷。 经典的垃圾收集器(技术咨询vx:keyichen_free) 1.Serial收集器 显而易见,这是一个单线程的收集器,其意义…

如何建立制造业设备巡检系统?零代码工具起关键性作用

什么设备巡检系统 设备巡检系统是一种管理工具,用于监测和记录设备运行状况,并在需要时指示工作人员进行巡检、维护或维修。这些系统通常由计算机软件和一组传感器或控制器组成,可监测各种设备的运行状况,如机器、设备、管线和车…

MATLAB 之 数据插值、曲线拟合和数值微分

这里写目录标题 一、数据插值1. 一维数据插值2. 二维数据插值 二、曲线拟合1. 曲线拟合原理2. 曲线拟合的实现 三、数值微分1. 数值差分与差商2. 数值微分的实现 一、数据插值 在工程测量和科学实验中,所得到的数据通常都是离散的。如果要得到这些离散点以外的其他…

计算机毕业论文内容参考|基于python的农业温室智能管理系统的设计与实现

文章目录 导文文章重点前言课题内容相关技术与方法介绍技术分析技术设计技术设计技术实现方面系统测试和优化总结与展望本文总结后续工作展望导文 计算机毕业论文内容参考|基于python的农业温室智能管理系统的设计与实现 文章重点 前言 本文介绍了一种基于Python的农业温室智…