返回顶部
首页 > 资讯 > 后端开发 > Python >JVM常见垃圾收集器学习指南
  • 347
分享到

JVM常见垃圾收集器学习指南

2024-04-02 19:04:59 347人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录前言垃圾收集器类型1. Serial收集器1.1 定义1.2 优点1.3 使用的垃圾收集算法1.4 应用场景1.5 工作流程2. Serial Old收集器2.1 定义2.2 优

前言

垃圾收集器 是 垃圾收集算法 的具体实现

本文将对市面上常见的垃圾收集器类型进行讲解,希望你们会喜欢

垃圾收集器类型

垃圾收集器 是 垃圾收集算法 的具体实现

现在主流的垃圾收集器有 7 种:

我们会根据需求场景的不同,选择不同特点的垃圾收集器

下面我会详细介绍。

1. Serial收集器

1.1 定义

最基本、发展历史最长的垃圾收集器

1.2 优点

  • 并发收集 在进行垃圾收集时,必须暂停其他所有工作线程Stop The World),直到收集结束。

暂停工作线程 是在用户不可见的情况下进行

注:并发 与 并行的区别 a. 并发:在 某一时段内,交替执行多个任务(即先处理A再处理B,循环该过程) b. 并行:在 某一时刻内,同时执行多个任务(即同时处理A、B)

  • 单线程 只使用 一条线程 完成垃圾收集(GC线程)
  • 效率高 对于限定单CPU环境来说,Serial收集器没有线程交互开销(专一做垃圾收集),拥有更高的单线程收集效率。

垃圾收集高效,即其他工作线程停顿时间短(可控制在100ms内),只要垃圾收集发生的频率不高,完全可以接受。

1.3 使用的垃圾收集算法

复制 算法

1.4 应用场景

客户端模式下,虚拟机的 新生代区域

1.5 工作流程

2. Serial Old收集器

2.1 定义

Serial收集器 应用在老年代区域 的版本

2.2 优点

并发、单线程、效率高

Serial收集器,此处不作过多描述

2.3 使用的垃圾收集算法

标记-整理 算法

2.4 应用场景

  • 在客户端模式下,虚拟机的老年代区域
  • 服务器模式下:

    Parallel Scavenge 收集器搭配使用

    作为CMS收集器的后备预案,在并发收集发生Concurrent Mode Failure时使用

2.5 工作流程

3. ParNew 收集器

3.1 定义

Serial收集器 的 多线程 版本。

3.2 优点

  • 并发收集 在进行垃圾收集时,必须暂停其他所有工作线程(Stop The World),直到收集结束。

暂停工作线程 是在用户不可见的情况下进行

  • 多线程收集 使用 多条垃圾收集线程(GC线程) 完成垃圾收集

由于存在线程交互的开销,所以在单CPU环境下,性能差于 Serial收集器

  • CMS收集器配合工作 目前,只有ParNew 收集器能与 CMS收集器 配合工作
  • 由于CMS收集器使用广泛,所以该特点非常重要。
  • 关于CMS收集器 下面会详细说明

3.3 使用的垃圾收集算法

复制 算法

3.4 应用场景

服务器模式下,虚拟机的 新生代区域

多线程收集

3.5 工作流程

4. Parallel Scavenge收集器

4.1 定义

ParNew 收集器的升级版

4.2 特点

  • 具备ParNew 收集器并发、多线程收集的特点
  • 以达到 可控制吞吐量 为目标 其他收集器的目标是: 尽可能缩短 垃圾收集时间,而Parallel Scavenge收集器的目标则是:达到 可控制吞吐量
  • 吞吐量:CPU用于运行用户代码的时间 与 CPU总消耗时间(运行用户代码时间+垃圾收集时间)的比值
  • 如:虚拟机总共运行100分钟,其中垃圾收集时间=1分钟、运行用户代码时间 = 99分钟,那吞吐量 = 99 / 100 = 99%
  • 自适应 该垃圾收集器能根据当前系统运行情况,动态调整自身参数,从而达到最大吞吐量的目标。

该特性称为:GC 自适应的调节策略

这是Parallel Scavenge收集器与 ParNew 收集器 最大的区别

4.3 使用的垃圾收集算法

复制 算法

4.4 应用场景

服务器模式下,虚拟机的 新生代区域

4.5 工作流程

5. Parallel Old收集器

5.1 定义

Parallel Scavenge收集器 应用在老年代区域 的版本

5.2 特点

以达到 可控制吞吐量 为目标、自适应调节、多线程收集

Parallel Scavenge收集器

5.3 使用的垃圾收集算法

标记-整理 算法

5.4 应用场景

服务器模式下,虚拟机的 老年代区域

5.5 工作流程

6. CMS收集器

6.1 定义

Concurrent Mark Sweep,基于 标记-清除算法的收集器

6.2 特点

6.2.1 优点

并行 用户线程 & 垃圾收集线程同时进行。

即在进行垃圾收集时,用户还能工作。

  • 单线程收集 只使用 一条线程 完成垃圾收集(GC线程)
  • 垃圾收集停顿时间短 该收集器的目标是: 获取最短回收停顿时间 ,即希望 系统停顿的时间 最短,提高响应速度

6.2.2 缺点

  • 总吞吐量会降低 因为该收集器对CPU资源非常敏感,在并发阶段,虽不会导致用户线程停顿,但会因为占用部分线程(CPU资源)而导致应用程序变慢,总吞吐量会降低
  • 无法处理浮动垃圾 由于 并发清理时 用户线程还在运行,所以会有新的垃圾不断产生(即浮动垃圾),只能等到留待下一次GC时再清理掉。

因为这一部分垃圾出现在标记过程之后,所以CMS无法在当次GC中处理掉它们

因此,CMS无法等到老年代被填满再进行Full GC,CMS需要预留一部分空间。即所谓的:可能出现Concurrent Mode Failure失败而导致另一次Full GC产生。

垃圾收集后会产生大量内存空间碎片 因为 CMS收集器是基于“标记-清除”算法的。

6.3 使用的垃圾收集算法

标记-清除 算法

6.4 应用场景

重视应用的响应速度、希望系统停顿时间最短的场景

互联网移动端应用

6.5 工作流程

CMS 收集器 是基于 标记-清除算法实现的收集器,工作流程较为复杂:(分为四个步骤)

初始标记

  • 并发标记
  • 重新标记
  • 并发清除

下面用一张图详细说明工作流程:

  • 由于整个过程中,耗时最长的并发标记 和 并发清除过程都可与用户线程一起进行
  • 所以,CMS收集器的垃圾收集过程可看作是与用户线程 并发执行的。

7. G1 收集器

7.1 定义

最新、技术最前沿的垃圾收集器

7.2 特点

并行 用户线程 & 垃圾收集线程同时进行。

即在进行垃圾收集时,用户还能工作

多线程 即使用 多条垃圾收集线程(GC线程) 进行垃圾收集

并发 & 并行 充分利用多CPU、多核环境下的硬件优势 来缩短 垃圾收集的停顿时间

垃圾回收效率高 G1 收集器是 针对性 对 Java堆内存区域进行垃圾收集,而非每次都对整个 Java 堆内存区域进行垃圾收集。

G1收集器除了将 Java 堆内存区域分为新生代 & 老年代之外,还会细分为许多个大小相等的独立区域( Region),然后G1收集器会跟踪每个 Region里的垃圾价值大小,并在后台维护一个列表;每次回收时,会根据允许的垃圾收集时间 优先回收价值最大的Region,从而避免了对整个Java堆内存区域进行垃圾收集,从而提高效率。

因为上述机制,G1收集器还能建立可预测的停顿时间模型:即让 使用者 明确指定一个长度为M毫秒的时间片段内,消耗在垃圾收集上的时间不得从超出N毫秒。即具备实时性

分代收集 同时应用在 内存区域的新生代 & 老年代

不会产生内存空间碎片

从整体上看,G1 收集器是基于 标记-整理算法实现的收集器

从局部上看,是基于 复制算法 实现 上述两种算法意味着 G1 收集器不会产生内存空间碎片。

7.3 使用的垃圾收集算法

对于新生代:复制算法

对于老年代:标记 - 整理算法

7.4 应用场景

服务器端虚拟机的内存区域(包括 新生代 & 老年代)

7.5 工作流程

G1 收集器的工作流程分为4个步骤:

初始标记

  • 并发标记
  • 最终标记
  • 筛选回收

下面用一张图详细说明工作流程

8. 总结

本文对垃圾收集器的类型进行全面讲解

以上就是JVM常见垃圾收集器学习指南的详细内容,更多关于JVM垃圾收集器的资料请关注编程网其它相关文章!

--结束END--

本文标题: JVM常见垃圾收集器学习指南

本文链接: https://lsjlt.com/news/152459.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JVM常见垃圾收集器学习指南
    目录前言垃圾收集器类型1. Serial收集器1.1 定义1.2 优点1.3 使用的垃圾收集算法1.4 应用场景1.5 工作流程2. Serial Old收集器2.1 定义2.2 优...
    99+
    2024-04-02
  • JVM常见垃圾收集器有哪些
    这篇文章主要介绍了JVM常见垃圾收集器有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JVM常见垃圾收集器有哪些文章都会有所收获,下面我们一起来看看吧。垃圾收集器类型垃圾收集器 是 垃圾收集算法 的具体实现...
    99+
    2023-07-02
  • JVM垃圾回收——G1垃圾收集器
    目录 一、什么是G1垃圾收集器 二、G1垃圾收集器的内存划分 三、G1垃圾收集器的收集过程  四、G1收集器的优缺点 五、G1收集器的JVM参数配置 一、什么是G1垃圾收集器         Garbage First(简称G1)收集...
    99+
    2023-10-25
    jvm java G1
  • JVM中常见的垃圾收集器有哪些
    这篇文章主要介绍了JVM中常见的垃圾收集器有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。如果说收集算法是内存回收的方法论,那么垃圾收集器就是内存回收的具体实现。Java...
    99+
    2023-06-02
  • JVM常用垃圾收集器详细解说
    目录前言新生代垃圾收集器老年代垃圾收集器不分代垃圾收集器前言 在上一篇,我们谈到了jvm垃圾回收算法详细解析,并了解了JVM中针对堆区中不同的分代采用不同的垃圾回收算法 在了解了垃圾...
    99+
    2024-04-02
  • jvm默认垃圾收集器是什么
    JVM(Java虚拟机)的默认垃圾收集器取决于所使用的Java版本和操作系统。在JDK 8及之前的版本中,默认的垃圾收集器是Para...
    99+
    2023-09-26
    jvm
  • 学习java一定要知道的垃圾收集器
    目录垃圾收集器如何演化的?年轻代收集器SerialParNewParallel Scavenge老年代收集器SerialOldParallelOldCMS(ConcurrentMar...
    99+
    2024-04-02
  • 常见的垃圾回收器有哪些
    本篇文章给大家分享的是有关常见的垃圾回收器有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。作为一个 Java 开发,在面试的过程中垃圾回收...
    99+
    2024-04-02
  • java性能优化常见的垃圾收集器有哪些
    本文小编为大家详细介绍“java性能优化常见的垃圾收集器有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“java性能优化常见的垃圾收集器有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。常见的垃圾回收器和...
    99+
    2023-07-02
  • java性能优化四种常见垃圾收集器汇总
    目录前言常见的垃圾回收器和算法serial 串行垃圾收集器Parallel 多线程垃圾收集器CMS 收集器G1 收集器显式垃圾收集前言 本篇文章我们来具体看看如何选择合适的垃圾收集器...
    99+
    2024-04-02
  • 怎么查看JVM使用的默认的垃圾收集器
    本篇内容介绍了“怎么查看JVM使用的默认的垃圾收集器”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!查看JVM使用的默认的垃圾收集器查看步骤c...
    99+
    2023-06-25
  • 如何查看JVM使用的默认的垃圾收集器
    查看JVM使用的默认的垃圾收集器查看步骤cmd执行命令:java -XX:+PrintCommandLineFlags -version输出如下(举例):针对上述的-XX:UsePa...
    99+
    2024-04-02
  • JVM内存管理深入垃圾收集器与内存分配策略的示例分析
    这篇文章给大家介绍JVM内存管理深入垃圾收集器与内存分配策略的示例分析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的高墙,墙外面的人想进去,墙里面的人却想出...
    99+
    2023-06-17
  • C++技术中的机器学习:使用C++实现常见机器学习算法的指南
    在 c++++ 中,机器学习算法的实施方式包括:线性回归:用于预测连续变量,步骤包括加载数据、计算权重和偏差、更新参数和预测。逻辑回归:用于预测离散变量,流程与线性回归类似,但使用 si...
    99+
    2024-05-11
    机器学习 c++
  • 学习并掌握常见的canvas框架:绘图和动画制作的入门指南
    入门canvas框架:学习使用常见的canvas框架进行绘图和动画制作,需要具体代码示例 随着前端技术的快速发展,网页设计中的动态效果日益重要。而canvas作为一种用于在浏览器上绘制图形的HTML元素,已经成为了实现各种动画效...
    99+
    2024-01-17
    绘图 入门 Canvas框架
  • 深入学习Golang的打包实战指南: 探索使用Golang进行打包及解决常见问题的方法
    Golang打包实战指南:利用golang进行打包并解决常见问题引言:Golang是一门流行的编程语言,其强大的并发性和高效的编译器使其成为很多开发者的首选。在开发过程中,我们经常需要将我们的代码打包成可执行文件或库,以便在其他环境中部署和...
    99+
    2023-12-29
    Golang 打包 解决问题
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作