高级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…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...

铭豹扩展坞 USB转网口 突然无法识别解决方法
当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...
conda相比python好处
Conda 作为 Python 的环境和包管理工具,相比原生 Python 生态(如 pip 虚拟环境)有许多独特优势,尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处: 一、一站式环境管理:…...

Spark 之 入门讲解详细版(1)
1、简介 1.1 Spark简介 Spark是加州大学伯克利分校AMP实验室(Algorithms, Machines, and People Lab)开发通用内存并行计算框架。Spark在2013年6月进入Apache成为孵化项目,8个月后成为Apache顶级项目,速度之快足见过人之处&…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...
Java 8 Stream API 入门到实践详解
一、告别 for 循环! 传统痛点: Java 8 之前,集合操作离不开冗长的 for 循环和匿名类。例如,过滤列表中的偶数: List<Integer> list Arrays.asList(1, 2, 3, 4, 5); List<Integer> evens new ArrayList…...

家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
反射获取方法和属性
Java反射获取方法 在Java中,反射(Reflection)是一种强大的机制,允许程序在运行时访问和操作类的内部属性和方法。通过反射,可以动态地创建对象、调用方法、改变属性值,这在很多Java框架中如Spring和Hiberna…...
leetcodeSQL解题:3564. 季节性销售分析
leetcodeSQL解题:3564. 季节性销售分析 题目: 表:sales ---------------------- | Column Name | Type | ---------------------- | sale_id | int | | product_id | int | | sale_date | date | | quantity | int | | price | decimal | -…...
CMake控制VS2022项目文件分组
我们可以通过 CMake 控制源文件的组织结构,使它们在 VS 解决方案资源管理器中以“组”(Filter)的形式进行分类展示。 🎯 目标 通过 CMake 脚本将 .cpp、.h 等源文件分组显示在 Visual Studio 2022 的解决方案资源管理器中。 ✅ 支持的方法汇总(共4种) 方法描述是否推荐…...