JVM的几种常见垃圾回收算法

引言:

        Java Virtual Machine(JVM)作为Java程序运行的核心,其垃圾回收(Garbage Collection, GC)机制在内存管理中起着至关重要的作用。垃圾回收算法是JVM性能优化的重要方面。本文将详细介绍几种常见的垃圾回收算法,包括标记-清除(Mark-and-Sweep)、复制(Copying)、标记-整理(Mark-and-Compact)、分代收集(Generational Collection)和G1(Garbage-First)等。

1. 标记-清除(Mark-and-Sweep)

标记-清除算法是最基础的垃圾回收算法之一,其主要过程分为两个阶段:标记和清除。

标记阶段

从根对象(GC Roots)开始,遍历整个对象图,标记所有可达对象。可达对象即从GC Roots出发可以直接或间接引用到的对象。

清除阶段

遍历整个堆内存,清除所有未标记的对象,将它们的内存空间回收。

 

优点

  • 实现简单,算法逻辑清晰。

缺点

  • 标记和清除过程会导致应用程序暂停(Stop-The-World),影响性能。
  • 清除阶段会产生内存碎片,导致大对象分配困难。

2. 复制(Copying)

复制算法通过将内存划分为两块相等的区域,称为“From空间”和“To空间”,每次只使用其中的一块。

回收过程

  1. 从根对象开始,标记并复制所有可达对象到To空间。
  2. 复制过程中,更新对象的引用。
  3. 复制完成后,清空From空间,交换From和To空间的角色。

 

优点

  • 每次回收后,To空间中的对象是连续分布的,不会产生内存碎片。
  • 回收效率较高,尤其适用于存活对象较少的情况。

缺点

  • 需要两块相同大小的内存区域,空间浪费较大。
  • 不适用于存活对象较多的情况。

3. 标记-整理(Mark-and-Compact)

标记-整理算法结合了标记-清除和复制算法的优点,适用于老年代的垃圾回收。

回收过程

  1. 标记阶段与标记-清除算法相同,标记所有可达对象。
  2. 整理阶段,将所有存活对象向堆的一端移动,保持内存的连续性。
  3. 移动完成后,清除后半部分的内存空间。

优点

  • 避免了内存碎片问题。
  • 内存利用率高,不需要额外的空间。

缺点

  • 对象移动过程较复杂,需要更新所有引用,回收效率相对较低。

4. 分代收集(Generational Collection)

分代收集算法基于对象的生命周期特点,将堆内存划分为年轻代(Young Generation)和老年代(Old Generation)。

年轻代

年轻代包括Eden区和两个Survivor区(From和To)。大部分对象在年轻代分配,年轻代的GC称为Minor GC。

老年代

老年代存放经过多次GC仍然存活的对象,老年代的GC称为Major GC或Full GC。

优点

  • 大多数对象在年轻代分配和回收,利用复制算法进行Minor GC,效率高。
  • 老年代采用标记-整理算法,减少内存碎片。

缺点

  • 需要根据对象的生命周期进行分代管理,算法实现较复杂。

5. G1(Garbage-First)

G1垃圾回收器是JVM的一种面向服务端应用的高性能垃圾回收器,设计目标是提供高吞吐量和低暂停时间。

工作原理

G1将堆内存划分为多个大小相等的区域(Region),每个Region可以作为年轻代或老年代的一部分。GC过程分为年轻代GC和混合GC(Mixed GC)。

回收过程

  1. 年轻代GC:类似于分代收集的Minor GC,仅回收年轻代的Region。
  2. 混合GC:回收整个堆,包括年轻代和部分老年代的Region,根据回收收益优先选择垃圾最多的Region。

优点

  • 可以控制GC的停顿时间,适合大内存的应用场景。
  • 回收效率高,能够处理堆内存碎片问题。

缺点

  • 算法实现复杂,参数调整难度较大。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/703403.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring Cloud Stream整合RocketMQ

Spring Cloud Stream整合RocketMQ 这里书接上回,默认你已经搭建好了RocketMQ主从异步集群,前面文章已经介绍过搭建方法。 1、Spring Cloud Stream介绍 Spring Cloud Stream是一个框架,用于构建与共享消息系统连接的高度可扩展的事件驱动微服…

11. 利用MS为Lammps ReaxFF建模(PE/聚乙烯)基础-2

来源: “码农不会写诗”公众号 链接:利用MS为Lammps ReaxFF建模(PE/聚乙烯)基础-2 文章目录 01 msi2lmp工具简介1. 编译生成msi2lmp可执行文件2. 使用方式 02 赋予模型CVFF力场03 导出car/mdf文件04 生成data文件05 data文件进一步处理 文接上篇 上篇利用…

大模型高级 RAG 检索策略之流程与模块化

我们介绍了很多关于高级 RAG(Retrieval Augmented Generation)的检索策略,每一种策略就像是机器中的零部件,我们可以通过对这些零部件进行不同的组合,来实现不同的 RAG 功能,从而满足不同的需求。 今天我们…

Android RTSP/RTMP多路播放时动态切换输出View类型(SurfaceView和TextureView 动态切换)

SurfaceView和TextureView的区别和优缺点等, 相关的资料很多. 从Android低延时播放器实现角度来看, 总结了下主要区别有: 1. MediaCodec输出到SurfaceView延时一般比到TextureView更低. 2. MediaCodec用SurfaceView比TextureView占用的资源一般更少些(CPU和内存都小一些, 不过还…

算法专题总结链接地址

刷力扣的时候会遇到一些总结类型的题解,在此记录,方便自己以后找 前缀和 前缀和https://leetcode.cn/problems/unique-substrings-in-wraparound-string/solutions/432752/xi-fa-dai-ni-xue-suan-fa-yi-ci-gao-ding-qian-zhui-/ 单调栈 单调栈https:…

论文解读——《I2EDL: Interactive Instruction Error Detection and Localization》

一、研究背景 视觉与语言导航(VLN)是一个AI领域的研究任务,旨在开发能够按照自然语言指令在三维空间中导航到指定位置的智能体。这项任务与人类的日常活动——如按照口头指示到达某个地点——十分相似,对于推动人机交互的自然性和…

k8s学习--kubernetes服务自动伸缩之水平伸缩(pod副本伸缩)HPA详细解释与案例应用

文章目录 前言HPA简介简单理解详细解释HPA 的工作原理监控系统负载模式HPA 的优势使用 HPA 的注意事项应用类型 应用环境1.metircs-server部署2.HPA演示示例(1)部署一个服务(2)创建HPA对象(3)执行压测 前言…

汇聚荣科技有限公司实力强吗?

汇聚荣科技有限公司实力强吗?在当今快速发展的科技行业中,公司的实力往往决定了其市场竞争力和发展前景。对于汇聚荣科技有限公司而言,其是否具备强大的实力,不仅关系到自身的发展,也影响着投资者和合作伙伴的选择。因此&#xf…

集成算法实验(Bagging策略)

Bagging模型(随机森林) Bagging:训练多个分类器取平均 f ( x ) 1 / M ∑ m 1 M f m ( x ) f(x)1/M\sum^M_{m1}{f_m(x)} f(x)1/M∑m1M​fm​(x) 全称: bootstrap aggregation(说白了就是并行训练一堆分类器) 最典型的代表就是随…

[ue5]建模场景学习笔记(6)——必修内容可交互的地形,交互沙(4)

1.需求分析: 现在我们已经有了可以在世界内近于无限的跑动痕迹,现在需要对痕迹进行细化,包括例如当人物跳起时便不再绘制痕迹,以及痕迹应该存在深浅,应该由两只脚分别绘制,同时也应该对地面材质进行进一步处…

国内核心期刊基本情况

对于广大师生来说,发表核心期刊论文是当前阶段绕不开的任务,有的高校晋升副高需要发表核心论文5篇以上,有的学校硕博研究生毕业条件必须是一作发核心。很多人对核心的理解仅停留在“北核、南核”,其他的一概不知。但是我国的核心期…

CG-85C 振弦式土压力计厂家 结构物内部土压力变化量如何测量?

产品概述 振弦式土压力计由背板、感应板、信号传输电缆、振弦及激振电磁线圈等组成,是了解被测结构物内部土压力变化量、并可同步测量埋设点温度的监测设备。 功能特点 ◆精度高,能够提供准确的测量结果。 ◆稳定性好,不易受到外界因素的…

端点物联开发教程之(一)什么是端点物联

目录 一、手机端演示 二、开发套件 三、嵌入式端 四、平台端 五、手机端 本项目的交流QQ群:701889554 物联网实战--入门篇https://blog.csdn.net/ypp240124016/category_12609773.html 物联网实战--驱动篇https://blog.csdn.net/ypp240124016/category_12631333.html 物…

centos7 安装 mysql5.7 LTS

centos7 安装 mysql5.7 LTS 参考: https://blog.csdn.net/EB_NUM/article/details/105425622 可以在运行安装程序之前导入密钥: sudo rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022第一步、下载MySQL 安装包: sudo wget h…

【QT5】<总览二> QT信号槽、对象树及常用函数

文章目录 前言 一、QT信号与槽 1. 信号槽连接模型 2. 信号槽介绍 3. 自定义信号槽 二、QT的对象树 三、添加资源文件 四、样式表的使用 五、QSS文件的使用 六、常用函数与宏 前言 承接【QT5】<总览一> QT环境搭建、快捷键及编程规范。若存在版…

vs2015+win10编译LAStools

文章目录 下载LasTool安装包编译laslib测试 下载LasTool安装包 不要再GitHub上下载,在官网下载:link 编译laslib 将压缩包解压到对应路径下,注意路径下不要有空格和汉字。用vs打开目录下的 “lastools.dsw” 文件 下面注意几点&#xff1a…

代码随想录算法训练营第36天(py)| 贪心 | 452. 用最少数量的箭引爆气球、435. 无重叠区间、763.划分字母区间

452. 用最少数量的箭引爆气球 力扣链接 有一些球形气球贴在一堵用 XY 平面表示的墙面上。墙面上的气球记录在整数数组 points ,其中points[i] [xstart, xend] 表示水平直径在 xstart 和 xend之间的气球。你不知道气球的确切 y 坐标。 一支弓箭可以沿着 x 轴从不同…

python 10个高频率的自动化脚本(干货,速度收藏)

1. 文件操作:自动备份文件 场景:每日自动备份重要文件到指定目录。 import shutilimport datetimedef backup_file(src, dst_folder): now datetime.datetime.now().strftime(%Y%m%d%H%M%S) dst_path f"{dst_folder}/backup_{now}_{src.s…

Qt 实战(4)信号与槽 | 4.1、信号与槽机制

文章目录 一、信号与槽机制1、基本概念2、信号与槽函数连接2.1、connect宏实现信号与槽连接2.2、Qt5新connect函数2.3、使用函数指针2.4、使用lambda表达式2.5、使用Qt Creator添加信号的槽函数 3、结论 前言: Qt信号与槽机制是一种用于处理对象间通信的强大机制&am…

精品KEITHELY6517B参数资料/静电计/高阻计

Keithley 5 位 6517B 静电计/高阻计提供最先进的精度和灵敏度规格,并具有各种功能,可简化高阻和绝缘材料电阻率的测量。Keithley 6517B 的读数速率高达 425 次/秒,可快速、轻松地测量低电平电流。 Keithley 6517B 是更新版本,取代…