高级java每日一道面试题-2024年10月18日-JVM篇-说下你对G1垃圾收集器的理解?
如果有遗漏,评论区告诉我进行补充
面试官: 说下你对G1垃圾收集器的理解?
我回答:
在Java高级面试中,G1垃圾收集器是一个经常被提及的话题。以下是对G1垃圾收集器的详细解析:
G1垃圾收集器的概述
G1(Garbage-First)垃圾收集器是Java虚拟机(JVM)的一种服务器端垃圾收集器,专为大堆内存和多处理器机器设计。它在Java 7中被引入,目的是提供一个可预测的停顿时间,同时提高吞吐量。G1垃圾收集器试图以很高的概率满足GC停顿时间目标,同时实现高吞吐量且几乎不需要配置。
G1垃圾收集器的关键特性
堆分区(Heap Region)
- 分区设计:G1将整个堆内存划分为多个大小相等的区域(Region),每个区域可以是 Eden、Survivor 或 Old 区域。这种设计使得 G1 可以并行处理这些小区域,从而提高效率。
- 灵活的区域分配:G1 不再使用传统的连续内存空间来划分新生代和老年代,而是根据需要动态地将区域分配为 Eden、Survivor 或 Old。
优先级收集
- G1跟踪各个Region中垃圾的数量,并优先收集那些垃圾最多的Region,这就是其名称“Garbage-First”的由来。通过这种方式,G1减少了每次垃圾回收的停顿时间。
停顿时间预测
- 可控的停顿时间:G1 收集器允许用户设置最大停顿时间(通过
-XX:MaxGCPauseMillis参数),G1 会尽量在这个时间内完成垃圾收集。 - 自适应调整:G1 会根据历史数据和当前系统状态动态调整收集策略,以达到设定的停顿时间目标。
并行和并发
- 并行收集:G1 的所有阶段都可以并行执行,利用多核处理器的优势,提高垃圾收集的效率。
- 并发标记:G1 的标记阶段可以与应用程序并发执行,减少停顿时间。
软实时性能
- G1旨在提供软实时性能,即在大部分时间里满足用户指定的停顿时间目标。
无全局垃圾回收
- G1避免了全堆的垃圾回收,只在必要时进行Full GC,这减少了Full GC的频率和影响。
更好的大堆内存管理
- 对于大堆内存,G1通过分区减少了内存回收的复杂性,提高了内存利用率。
适应性
- G1可以根据应用程序的行为动态调整垃圾回收的策略,以适应不同的工作负载。
减少内存碎片
- G1在回收过程中会进行内存压缩,减少了内存碎片,有助于提高内存分配的效率。
混合收集(Mixed Collection)
- 混合收集:当老年代的垃圾回收不足以满足停顿时间目标时,G1 会启动混合收集模式。在这种模式下,G1 会同时收集年轻代和部分老年代的区域。
- 选择性收集:G1 会选择那些垃圾最多的区域进行收集,因此得名“Garbage-First”。
易于配置
- G1提供了简单的JVM参数,如-XX:MaxGCPauseMillis来设置最大GC停顿时间,使得性能调优更加容易。
G1垃圾收集器的工作机制
- 分代收集:G1依然属于分代型垃圾回收器,它会区分年轻代和老年代。但从堆的结构上看,它不要求整个Eden区、年轻代或者老年代都是连续的,也不再坚持固定大小和固定数量。
- 并行和并发:G1在回收期间,可以有多个GC线程同时工作,有效利用多核计算能力。同时,G1拥有与应用程序交替执行的能力,部分工作可以和应用程序同时执行。
- 空间整合:G1将内存划分为一个个的region,内存的回收是以region作为基本单位的。Region之间是复制算法,但整体上实际可看作是标记-压缩(Mark-Compact)算法,两种算法都可以避免内存碎片。
- 可预测的停顿时间模型:G1除了追求低停顿外,还能建立可预测的停顿时间模型,能让使用者明确指定在一个长度为M毫秒的时间片段内,消耗在垃圾收集上的时间不得超过N毫秒。
- 疏散回收空间:G1主要通过疏散回收空间。回收时,在选定的内存区域内发现的活动对象被复制到新的内存区域,在此过程中压缩它们。疏散完成后,由先前活动对象占据的空间被重新用于应用程序的分配。
工作流程
G1 的垃圾收集过程主要分为以下几个阶段:
初始标记(Initial Marking)
- 目标:标记出从 GC Roots 直接可达的对象。
- 特点:这个阶段是 STW(Stop-The-World)的,但通常非常快。
并发标记(Concurrent Marking)
- 目标:从初始标记的对象开始,递归地标记所有可达的对象。
- 特点:这个阶段与应用程序并发执行,不会导致长时间的停顿。
最终标记(Final Marking)
- 目标:修正并发标记期间由于应用程序运行而产生的变化。
- 特点:这个阶段也是 STW 的,但通常比初始标记要长一些。
筛选回收(Live Data Counting and Evacuation)
- 目标:计算每个区域的存活对象数量,并确定哪些区域需要被回收。
- 特点:筛选回收阶段是 STW 的,但它只处理那些需要回收的区域,因此停顿时间较短。
更新指针(Pointer Update)
- 目标:更新指向已移动对象的引用。
- 特点:这个阶段可以并发执行,也可以在 STW 阶段完成。
优势
- 高吞吐量:G1 通过并行处理和高效的垃圾收集算法,提供了较高的吞吐量。
- 低延迟:G1 通过控制停顿时间和混合收集模式,减少了垃圾收集对应用程序的影响。
- 大内存支持:G1 特别适合处理大内存堆的应用程序,能够有效地管理数十GB甚至TB级别的堆内存。
缺点
- 额外开销:G1 为了实现其功能,需要维护更多的元数据和指针信息,这可能会增加一定的内存开销。
- 复杂性:G1 的内部机制相对复杂,调试和调优可能需要更多的专业知识。
G1垃圾收集器的应用场景
如果应用程序具有以下一个或多个特性,可以考虑使用G1回收器:
- 堆内存超过6GB或更大,并且稳定且可预测的暂停时间低于0.5秒(在Java 19中推荐10GB或者更大的堆内存)。
- 堆内存占用实时数据超过50%。
- 对象分配和晋升的速度非常快。
- 应用程序不希望垃圾回收或内存压缩的暂停时间超过0.5秒到1秒。
配置参数
-XX:+UseG1GC:启用 G1 垃圾收集器。-XX:MaxGCPauseMillis=N:设置最大停顿时间目标(毫秒)。-XX:G1HeapRegionSize=n:设置每个区域的大小(建议值为 1MB 到 32MB 之间)。-XX:InitiatingHeapOccupancyPercent=N:设置触发并发标记的堆占用百分比。
总结
G1 垃圾收集器通过分区设计、并行与并发处理、停顿预测模型以及混合收集模式,提供了高吞吐量和低延迟的垃圾收集体验。它特别适用于大内存堆的应用程序,并且可以通过配置参数来优化性能。
相关文章:
高级java每日一道面试题-2024年10月18日-JVM篇-说下你对G1垃圾收集器的理解?
如果有遗漏,评论区告诉我进行补充 面试官: 说下你对G1垃圾收集器的理解? 我回答: 在Java高级面试中,G1垃圾收集器是一个经常被提及的话题。以下是对G1垃圾收集器的详细解析: G1垃圾收集器的概述 G1(Garbage-First)垃圾收集器…...
2024系统架构师---湖仓一体架构论文知识点
湖仓一体架构深度解析:构建企业级数据管理与分析的新基石 在当今数据驱动的时代,企业对于数据的管理与分析需求日益复杂。传统的数据仓库与数据湖架构虽各有优势,但单独使用时往往难以满足企业的全面需求。湖仓一体(Lakehouse&am…...
Unity性能优化
前言 当游戏开发使用传统的OPP(面向对象编程)面对大量的Game object时FPS会显著降低,而使用Dots(面向数据编程)性能依旧很好 计算机内存基础 CPU自身有三级高速缓存,L1,L2,L3,其中CPU访问(L1…...
MyHdfs代码分享
关于hdfs协议层相关的的解析已经比较全面,但是大多的分析停留在理论层面。为此笔者通过对hadoop源码的整理,完成了myhdfs项目。此项目有个特点是不依赖于任何hadoop的maven包,但却可以作为原生的hadoop客户端的server。项目暂时已经完成了rpc…...
Java网络编程-简单的API调用
Get请求 - 无参数 安装依赖库 首先需要安装一个库: Okhttp3,这是一个非常流行的 HTTP 库,可以简单、快速的实现 HTTP 调用。 安装 Okhttp3 的方式是在 pom.xml 文件中增加依赖: <!-- https://mvnrepository.com/artifact/c…...
论文笔记(五十)Segmentation-driven 6D Object Pose Estimation
Segmentation-driven 6D Object Pose Estimation 文章概括摘要1. 引言2. 相关工作3. 方法3.1 网络架构3.2 分割流3.3 回归流3.4 推理策略 4. 实验4.1 评估 Occluded-LINEMOD4.1.1 与最先进技术的比较4.1.2 不同融合策略的比较4.1.3 与人体姿态方法的比较 4.2 在YCB-Video上的评…...
微服务的一些基本概念
目录 1 概述1.1 微服务架构的特征1.2 微服务架构示例 2 微服务与单体式架构2.1 什么是单体式架构?2.2 单体式架构的优点2.3 单体式架构的缺点 3 什么是微服务?3.1 微服务的优点3.2 微服务的缺点 4 如何构建微服务4.1 从单体式开始4.2 以正确的方式组织团…...
el-table修改指定列字体颜色 ,覆盖划过行的高亮显示文字颜色
修改指定列字体颜色 ,覆盖划过行的高亮显示文字颜色 代码如下: <div class"c1"><el-table:data"tableData"striperow-class-name"custom-table-row"style"width:100%"cell-mouse-enter"lightFn"cell-…...
java高频面试题汇总
Java 基础 Java 中的序列化和反序列化是什么? 序列化是将 Java 对象转换为字节流的过程,以便可以将其存储在文件中或通过网络进行传输。反序列化则是将字节流恢复为 Java 对象的过程。通过实现 Serializable 接口,Java 对象可以支持序列化。…...
Docker安装ocserv教程(效果极佳)
本章教程,介绍如何在Debain系统上安装ocserv。安装方式是使用Docker方式部署。 一、安装Docker curl -sSL https://file.ewbang.com/docker/debian/install_docker.sh -o install_docker.sh && bash install_docker.sh二、拉取镜像 docker pull tommylau/ocserv...
【数据结构与算法】第3课—数据结构之单链表
文章目录 1. 什么是链表2. 单链表2.1 单链表的初始化和打印2.2 单链表的尾插和头插2.3 单链表的尾删和头删2.4 单链表查找节点2.5 单链表在指定位置之前/之后插入数据2.6 单链表删除节点和删除pos之后的节点2.7 销毁链表 3. 单链表和顺序表对比 1. 什么是链表 链表是在逻辑结构…...
linux—基础命令及相关知识
1.0Linux的哲学思想(优势) 1、一切都是一个文件,一切硬件设备包括硬件接口都可以以文件形式显示 2、系统小型,轻量级,300个包(不装桌面的情况下) 3、避免令人困惑的用户界面(图形…...
Spring Boot 实现 WebSocket(注解方式)
本文介绍如何使用 Spring Boot 的注解方式实现一个简单的 WebSocket 服务,支持客户端与服务器之间进行实时通信。 1. 引入依赖 在 pom.xml 文件中添加 WebSocket 相关依赖。 <dependencies><!-- Spring Boot WebSocket 支持 --><dependency>&l…...
windows下Qt的安装方法
Qt Creator是个人非常喜欢的一款开发工具,喜欢用其来开发C和CPC平台项目,当然也可以用其来开发Android和Auto平台项目,但其现在采用离线安装,限于网络问题,安装速度非常慢。 现在介绍一种可以完成快速的安装方法。 下…...
嵌入式面试题 ARM常见面试题
一.ARM内核分为哪几类?他们之间有什么区别? ARM内核主要分为三类,Cortex-A,Cortex-R,Cortex-M三种,A代表Applications,向用户提供全方位解决方案,主要用于复制的应用场合,比如智能手机、移动计算平台,数字电视、机顶盒、打印机或服务器等。R代表Real-Time Embedded,…...
分布式调度器--Spring Task 的使用
目录 1、启动类(App.java)上加EnableScheduling注解: 开启基于注解的任务调度器 2、同步定时任务 3、多线程(异步)定时任务 3.1 配置线程池 3.2 开启异步支持 3.3 定义异步方法 4、Api说明 4.1 fixedDelay 4.…...
Java应用程序的测试覆盖率之设计与实现(四)-- jacoco-maven-plugin
一、什么是jacoco-maven-plugin jacoco源码jacoco文档 除了使用jacoco.cli.jar导出并生成覆盖率报告外,还可以使用jacoco-maven-plugin,它是maven集成了jacoco的一款插件。 在工程pom.xml里配置插件jacoco-maven-plugin。 <plugin><groupId&g…...
UI 提供的 progress-step 要怎么实现?
前言 这天突然收到了 UI 修改设计稿的消息通知:“xxx 已修改 xxx 项目并 了你,请及时查看变更内容”,一条、两条、三条 …,修改消息铺天盖地而来,然后就什么都看不到了(因为我选择开启消息免打扰…...
DBSwitch和Seatunel
一、DBSwitch 什么是DBSwitch?它主要用在什么场景? 通过步骤分析可以看到这个是通过配置数据源,采用一次性或定时方案,同步到数据仓库的指定表,并且指定映射关系的工具。有点类似于flinkcdc的增量同步。 参考: dbs…...
【日志】力扣刷题 -- 轮转数组
2024.10.06 【力扣刷题】 经典面试150—转轮数组—中等 189. 轮转数组 - 力扣(LeetCode) 第一次做,暴力循环 // 超出时间限制 void rotate(int* nums, int numsSize, int k) {for(int i 0; i < k; i){int right numsSize - 1;int temp…...
从一次生产事故复盘:我们如何优雅地处理用户上传的‘异常’Excel文件(附Apache POI配置详解)
从生产事故到防御体系:构建Excel文件处理的工程化解决方案那天凌晨2点,我被一阵急促的告警声惊醒。监控系统显示,核心文件处理服务的错误率在10分钟内飙升到35%,大量用户上传的Excel文件无法正常解析。更糟糕的是,部分…...
IPFS去中心化存储实战指南:黑马程序员音乐播放器项目开发完整教程
IPFS去中心化存储实战指南:黑马程序员音乐播放器项目开发完整教程 【免费下载链接】BlockChain 黑马程序员 120天全栈区块链开发 开源教程 项目地址: https://gitcode.com/gh_mirrors/blockchain95/BlockChain 你是否想过如何构建一个真正去中心化的音乐播放…...
DISMTools企业部署:在组织中大规模应用的最佳实践
DISMTools企业部署:在组织中大规模应用的最佳实践 【免费下载链接】DISMTools The connected place for Windows system administration 项目地址: https://gitcode.com/GitHub_Trending/di/DISMTools DISMTools是一款专为Windows系统管理设计的连接平台&…...
基于Arduino的模块化DIY智能时钟:从RTC到RGB LED的完整实现
1. 项目概述:打造一台高度可定制的DIY RGB LED时钟如果你和我一样,对市面上千篇一律的电子钟感到审美疲劳,同时又对Arduino和电子DIY充满热情,那么这个项目可能就是为你准备的。我们不是在简单地组装一个套件,而是在亲…...
微信小程序3D开发框架技术对比:XR-Frame与threejs-miniprogram
随着微信小程序逐步支持3D渲染与AR能力,开发者面临两个主要官方方案:自研的XR-Frame和适配Three.js的threejs-miniprogram。本文将从架构设计、渲染机制、功能集成、开发模式及适用场景等维度进行技术分析,为技术选型提供参考。一、XR-Frame&…...
Keil µVision链接器错误204解决方案
1. 问题现象与背景解析最近在使用Keil Vision进行嵌入式开发时,不少工程师遇到了一个令人头疼的链接器错误。具体表现为编译时出现"FATAL ERROR 204: INVALID KEYWORD"的致命错误,错误位置指向链接器控制文件中的特定行。这个问题在C166和C51两…...
Postgresql基础实践教程(八)
⭐️⭐️⭐️⭐️⭐️ 完整数据详见 练习数据免费 ⭐️⭐️⭐️⭐️⭐️ 六十九、查找会员ID 27的向上推荐链 问题 查找会员ID 27的向上推荐链:即推荐该会员的人,以及推荐那个人的人,依此类推。返回会员ID、名字和姓氏。按会员ID降序排列。…...
AI IDE 革命:程序员正在被重新定义
很多开发者第一次使用 Cursor 的 CtrlK 或 Composer(高级多文件编辑模式)时,都会有一种强烈的、甚至让人有些脊背发凉的冲击感。 因为: 它已经不再是那个我们熟悉的、只能在原地等待光标落下的: “代码自动补全插件&am…...
OpenIPC开源固件:5分钟解锁网络摄像头的终极控制权
OpenIPC开源固件:5分钟解锁网络摄像头的终极控制权 【免费下载链接】firmware Alternative IP Camera firmware from an open community 项目地址: https://gitcode.com/gh_mirrors/fir/firmware 还在为网络摄像头的封闭系统而烦恼吗?想要完全掌控…...
别再只用递归了!用C语言栈实现非递归快速排序,内存效率提升实战
从递归到迭代:C语言栈实现非递归快速排序的工程实践 在嵌入式开发和大规模数据处理场景中,递归实现的快速排序常常面临栈溢出风险。当排序10万个元素的数组时,递归深度可能达到log₂100000≈17层,在仅有2KB栈空间的STM32F103上极易…...
