垃圾回收器

devtools/2024/10/18 5:49:44/

一、垃圾回收器的三种类型

1.串行

  1. 单线程执行:所有的垃圾回收工作都由单个线程完成,即在进行垃圾回收时,应用程序的其他所有线程都会停止。
  2. 简单而高效:由于单线程执行,实现上相对简单,适用于小型或中小型的应用程序。
  3. 停顿时间长:由于垃圾回收时会停止应用程序的所有线程,可能导致较长的停顿时间,不适合对响应时间要求严格的应用。
  4. 适用场景:通常用于开发、测试和小型应用的部署,或者作为学习和理解垃圾回收机制的起点。

开启参数:-XX:+UseSerialGC=Serial+SeriakOld(新时代标记复制,老年代标记整理,两个可以同时进行)

img

2.吞吐量优先

  1. 批量处理:将多个小任务合并成一个大任务进行处理,可以减少每个任务的开销,提高吞吐量。例如,在数据库操作中,批量插入数据通常比逐行插入数据的吞吐量更高。
  2. 增加并行度:通过并行处理多个任务来增加系统的吞吐量。例如,使用线程池来并发处理多个请求。
  3. 高效的资源利用:将任务均匀分布到各个资源单元(如服务器、CPU核心)上,以防止某些资源单元过载,提高整体系统的吞吐量。
  4. 适用场景:吞吐量优先策略适用于那些对响应时间不太敏感但需要处理大量数据或长时间运行的应用,如批处理系统、大数据处理等。

垃圾回收方式于串行相似只是使用了多线程进行处理

img

3.响应时间优先

3.1CMS 流程概述

  1. 初始标记(Initial Mark)
    • 目的:标记根对象(即应用程序可直接访问的对象)。
    • 特点:这一步骤会停顿应用程序的执行(STW,Stop-The-World),因为需要确保在标记期间对象的引用关系是稳定的。
  2. 并发标记(Concurrent Mark)
    • 目的:遍历并标记从根对象可达的所有对象。
    • 特点:此阶段在应用程序运行时进行,即在不暂停应用程序的情况下进行标记工作。垃圾回收线程与应用程序线程并发工作,标记堆中的对象。
  3. 重新标记(Remark)
    • 目的:纠正并发标记阶段期间发生的对象变化(如对象的引用关系变动)。
    • 特点:这一步骤会再次停顿应用程序的执行,以确保准确标记所有可达对象。
  4. 并发清除(Concurrent Sweep)
    • 目的:清除未被标记的垃圾对象,回收堆内存。
    • 特点:此阶段与应用程序线程并发进行,尽量减少停顿时间,清除垃圾对象并释放内存。

3.2GC参数

  • **-XX:+UseCMSInitiatingOccupancyOnly**:只根据设定的阈值触发垃圾回收,避免动态调整。
  • **-XX:+UseConcMarkSweepGC**:启用 CMS 垃圾回收器。
  • **-XX:CMSInitiatingOccupancyFraction**:设置触发 CMS 垃圾回收的堆内存占用阈值。

img

3.2.1注意事项
  • 第一次初始标记时会短时间阻塞其他线程并对根对象进行标记。
  • 重新标记是因为并发标记时程序在运行产生会产生垃圾。
  • 并发清理时程序也在运行产生垃圾,这些垃圾会留到下一次垃圾回收。
    并发标记时程序在运行产生会产生垃圾。
  • 并发清理时程序也在运行产生垃圾,这些垃圾会留到下一次垃圾回收。
  • 因为CMS是一种标记清除的方法,会产生内存碎片,当碎片过多时垃圾回收器会退化为SerialOld进行串行的垃圾回收。

http://www.ppmy.cn/devtools/124963.html

相关文章

初始操作系统篇(2)—— 操作系统的运行环境与体系结构

找往期文章包括但不限于本期文章中不懂的知识点: 个人主页:我要学编程(ಥ_ಥ)-CSDN博客 所属专栏: 操作系统 目录 操作系统的运行环境 操作系统的运行机制 中断 系统调用 操作系统的体系结构 大内核 微内核 优点 缺点 操作系统的运行…

java-实现一个简单的httpserver-0.5.0

背景 通常写了一些接口,需要通过临时的http访问,又不需要spring这么厚重的框架 功能 设置并发监控并发两个get请求一个是根路径,一个是other 具体代码 import com.sun.net.httpserver.HttpExchange; import com.sun.net.httpserver.Http…

计算机网络:数据链路层 —— 可靠传输服务

文章目录 可靠传输停止-等待 (SW) 协议超时重传机制分组编号机制ACK 丢失问题ACK 延迟问题 注意事项信道利用率 回退 N 帧 (GBN) 协议滑动窗口信道利用率无传输差错超时重传、回退N帧 累计确认 选择重传 (SR) 协议滑动窗口 可靠传输 若数据链路层向其上层提供的服务类型为可靠…

软件项目开发流程与团队分工整体认知——基于《信息系统项目管理师教程》(需求分析、系统设计、开发、测试、部署与运维、开发工具与管理软件)

文章目录 1、信息系统项目管理师教程——精简说明2、软件工程开发流程与团队分工详解2.1 需求分析2.2 系统设计2.3 开发2.4 测试2.5 部署与运维 3、开发工具与管理软件4、总结 1、信息系统项目管理师教程——精简说明 在《信息系统项目管理师教程》中,有一些章节对…

Postman最新V11版本关键更新一览

Postman作为接口测试中,被广泛应用的一款主流工具,以其丰富的功能,灵活方便的使用方式,广受欢迎。最新发布的V11版本则在向协作平台转型的过程中一路狂奔,增加大量全新的协作支持。下面我们就一起来看看都有哪些变化吧…

如何解决Elasticsearch容器因“Connection refused”导致的问题

在使用Elasticsearch时,尤其是将Elasticsearch部署在Docker容器中,可能会遇到连接被拒绝(Connection refused)的情况。 1. 问题现象 在执行Python脚本或其他操作时,可能会遇到如下错误提示: elasticsear…

网络安全(黑客技术)2024年100天学习计划

🤟 基于入门网络安全/黑客打造的:👉黑客&网络安全入门&进阶学习资源包 前言 什么是网络安全 网络安全可以基于攻击和防御视角来分类,我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术,而“蓝队”、…

Spring Boot在B2B医疗平台中的病历管理创新

第4章 系统设计 4.1 系统总体设计 系统不仅要求功能完善,而且还要界面友好,因此,对于一个成功的系统设计,功能模块的设计是关键。由于本系统可执行的是一般性质的学习信息管理工作,本系统具有一般适用性,其…