高级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…...
Spark 之 入门讲解详细版(1)
1、简介 1.1 Spark简介 Spark是加州大学伯克利分校AMP实验室(Algorithms, Machines, and People Lab)开发通用内存并行计算框架。Spark在2013年6月进入Apache成为孵化项目,8个月后成为Apache顶级项目,速度之快足见过人之处&…...
解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八
现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet,点击确认后如下提示 最终上报fail 解决方法 内核升级导致,需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...
Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务
通过akshare库,获取股票数据,并生成TabPFN这个模型 可以识别、处理的格式,写一个完整的预处理示例,并构建一个预测未来 3 天股价涨跌的分类任务 用TabPFN这个模型构建一个预测未来 3 天股价涨跌的分类任务,进行预测并输…...
Go 并发编程基础:通道(Channel)的使用
在 Go 中,Channel 是 Goroutine 之间通信的核心机制。它提供了一个线程安全的通信方式,用于在多个 Goroutine 之间传递数据,从而实现高效的并发编程。 本章将介绍 Channel 的基本概念、用法、缓冲、关闭机制以及 select 的使用。 一、Channel…...
群晖NAS如何在虚拟机创建飞牛NAS
套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享...
日常一水C
多态 言简意赅:就是一个对象面对同一事件时做出的不同反应 而之前的继承中说过,当子类和父类的函数名相同时,会隐藏父类的同名函数转而调用子类的同名函数,如果要调用父类的同名函数,那么就需要对父类进行引用&#…...
6️⃣Go 语言中的哈希、加密与序列化:通往区块链世界的钥匙
Go 语言中的哈希、加密与序列化:通往区块链世界的钥匙 一、前言:离区块链还有多远? 区块链听起来可能遥不可及,似乎是只有密码学专家和资深工程师才能涉足的领域。但事实上,构建一个区块链的核心并不复杂,尤其当你已经掌握了一门系统编程语言,比如 Go。 要真正理解区…...
云安全与网络安全:核心区别与协同作用解析
在数字化转型的浪潮中,云安全与网络安全作为信息安全的两大支柱,常被混淆但本质不同。本文将从概念、责任分工、技术手段、威胁类型等维度深入解析两者的差异,并探讨它们的协同作用。 一、核心区别 定义与范围 网络安全:聚焦于保…...
如何在Windows本机安装Python并确保与Python.NET兼容
✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…...
2.3 物理层设备
在这个视频中,我们要学习工作在物理层的两种网络设备,分别是中继器和集线器。首先来看中继器。在计算机网络中两个节点之间,需要通过物理传输媒体或者说物理传输介质进行连接。像同轴电缆、双绞线就是典型的传输介质,假设A节点要给…...
