深入理解Java虚拟机(JVM)中的垃圾回收器
垃圾回收(Garbage Collection, GC)是现代编程语言中用于管理内存的重要机制,特别是在Java虚拟机(JVM)中。
它的基本原理是自动检测和释放不再被程序使用的内存,以避免内存泄漏和提高程序执行效率。
1.GC的基本原理
-
内存管理模型:
- JVM的内存通常分为几个区域,包括堆(Heap)和栈(Stack)。其中,堆用于存储对象实例和数组,是GC主要工作的区域。
-
对象生命周期:
- 当程序创建对象时,它们被分配到堆上。对象在不再被引用时变得不可达。
- 垃圾回收器的主要任务是识别不再被引用的对象,并回收它们占用的内存。
-
GC的触发时机:
- JVM会定期或在特定条件下(如堆内存达到一定阈值)启动垃圾回收。
- 垃圾回收过程中,首先会暂停应用程序线程,然后进行不可达对象的标记和清理工作,最终释放未使用的内存。
2. 垃圾回收算法及其原理
Java中常见的垃圾回收算法包括标记-清除(Mark-Sweep)、复制(Copying)、标记-整理(Mark-Compact)以及分代垃圾回收算法。以下将详细介绍每种算法的原理和适用场景。
2.1 标记-清除算法(Mark-Sweep)
原理:
- 标记阶段:从根节点(如栈、静态变量)出发,标记所有能够被直接或间接引用的对象。
- 清除阶段:清除所有未被标记的对象,释放它们占用的内存空间。
优缺点:
- 优点:简单直接,实现相对容易。
- 缺点:会产生内存碎片,当无法找到足够大连续内存块时,可能导致频繁的内存分配失败。
示例代码:
// 假设有一个简单的类
class MyClass {// 一些字段和方法
}// 在代码中创建对象
MyClass obj1 = new MyClass();
MyClass obj2 = new MyClass();// 让 obj1 不再被引用
obj1 = null;// 触发垃圾回收
System.gc();
2.2 复制算法(Copying)
原理:
- 将堆内存分为两个区域,每次只使用其中一个。
- 将存活的对象从一个区域复制到另一个区域,然后清理当前区域中所有不再被引用的对象。
优缺点:
- 优点:减少了内存碎片化问题,内存分配更加简单和高效。
- 缺点:浪费一半的内存空间。
示例代码:
// 假设有一个较大的数组
int[] largeArray = new int[1000000];// 数组不再被引用
largeArray = null;// 触发垃圾回收
System.gc();
2.3 标记-整理算法(Mark-Compact)
原理:
- 类似于标记-清除,但在清除阶段,会将存活的对象往堆内存的一端移动,然后清理掉端边界外的内存,从而减少内存碎片。
优缺点:
- 优点:减少了内存碎片,节省了内存空间。
- 缺点:移动对象需要额外的时间开销。
2.4 分代算法(Generational)
原理:
- 根据对象的生命周期将堆分为多个代,通常是新生代和老年代。
- 大部分对象具有短生命周期,因此将新创建的对象放入新生代,并使用较快速的垃圾回收算法(如复制算法)进行管理;老年代使用更稳定的垃圾回收算法(如标记-整理)进行管理。
优缺点:
- 优点:提高了垃圾回收的效率,减少了全堆垃圾回收的频率。
- 缺点:需要额外的逻辑来管理不同代之间的对象移动和回收。
3. 垃圾回收器
Java的不同垃圾回收器针对不同的应用需求和性能优化选择了不同的回收算法和实现特性:
-
Serial GC:
- 算法:复制算法。
- 特点:单线程执行,适用于小型或单核心机器。
-
Parallel GC:
- 算法:复制算法和标记-整理算法。
- 特点:多线程执行,适合多核心机器和高吞吐量应用。
-
CMS GC(Concurrent Mark-Sweep):
- 算法:标记-清除算法和并发标记算法。
- 特点:通过并发标记阶段减少停顿时间,适用于响应时间敏感的应用。
-
G1 GC(Garbage-First):
- 算法:分代算法,结合复制算法和标记-整理算法。
- 特点:通过优先处理回收价值最大的区域提高整体性能和稳定性。
-
ZGC 和 Shenandoah GC:
- 算法:基于并发算法,专注于减少长时间停顿,适用于大内存和高吞吐量的应用。
4. JVM的配置
JVM的配置通过启动参数来设置,以满足应用程序的性能和需求。以下是常见的JVM配置参数:
-
选择垃圾回收器:
-XX:+UseSerialGC:使用Serial GC。-XX:+UseParallelGC:使用Parallel GC。-XX:+UseConcMarkSweepGC:使用CMS GC。-XX:+UseG1GC:使用G1 GC。-XX:+UseZGC:使用ZGC。-XX:+UseShenandoahGC:使用Shenandoah GC。
-
调整堆大小:
-Xms<size>:设置初始堆大小。-Xmx<size>:设置最大堆大小。
-
调整垃圾回收器相关参数:
-XX:NewSize=<size>:设置新生代大小。-XX:MaxNewSize=<size>:设置新生代最大大小。-XX:SurvivorRatio=<ratio>:设置Eden区和Survivor区的比例。
-
监控和调试:
-XX:+PrintGCDetails:打印详细的GC日志信息。-XX:+HeapDumpOnOutOfMemoryError:在内存溢出时生成堆转储文件。
通过合理配置这些参数,可以优化JVM的性能和内存管理,提升Java应用程序的稳定性和效率。选择适当的垃圾回收器和调整参数,是实现高性能Java应用的重要步骤。
结论
垃圾回收是Java语言的核心特性之一,有效的垃圾回收机制能够提升程序的性能和稳定性。理解垃圾回收的基本原理、不同的回收算法及其适用场景,以及如何通过JVM的配置来优化内存管理,对于Java开发人员至关重要。
相关文章:
深入理解Java虚拟机(JVM)中的垃圾回收器
垃圾回收(Garbage Collection, GC)是现代编程语言中用于管理内存的重要机制,特别是在Java虚拟机(JVM)中。 它的基本原理是自动检测和释放不再被程序使用的内存,以避免内存泄漏和提高程序执行效率。 1.GC的基…...
视频集市新增支持多格式流媒体拉流预览
流媒体除了常用实时流外还有大部分是以文件的形式存在,做融合预览必须要考虑多种兼容性能力,借用现有的ffmpeg生态可以迅速实现多种格式的支持,现在我们将按需拉流预览功能进行了拓展,正式支持了ffmpeg的功能,可快捷方…...
定时器-前端使用定时器3s轮询状态接口,2min为接口超时
背景 众所周知,后端是处理不了复杂的任务的,所以经过人家的技术讨论之后,把业务放在前端来实现。记录一下这次的离大谱需求吧。 如图所示,这个页面有5个列表,默认加载计划列表。但是由于后端的种种原因,这…...
python实践笔记(二): 类和对象
1. 写在前面 最近在重构之前的后端代码,借着这个机会又重新补充了关于python的一些知识, 学习到了一些高效编写代码的方法和心得,比如构建大项目来讲,要明确捕捉异常机制的重要性, 学会使用try...except..finally&…...
指定GPU跑模型
加上一个CUDA_VISIBLE_DEVICES0,2就行了,使用0卡和2卡跑模型,注意多卡有时候比单卡慢,4090无NVlink,数据似乎是通过串行的方式传输到多个gpu的,只不过单个gpu是并行计算,数据在gpu与gpu之间似乎是串行传输的…...
Windows桌面运维----第五天
1、华为路由怎们配置IP、划分vlan、互通: 1、用户模式→系统模式; 2、进入相关端口,配置IP地址; 3、开通相应vlan,设置vlanX、IP地址; 4、绑定相关端口,设置端口类型; 5、电脑设置IP&#…...
bash和dash的区别(及示例)
什么是bash、dash Bash(GNU Bourne-Again Shell)是许多Linux平台的内定Shell,事实上,还有许多传统UNIX上用的Shell,像tcsh、csh、ash、bsh、ksh等等。 GNU/Linux 操作系统中的 /bin/sh 本是 bash (Bourne-Again Shell) 的符号链接࿰…...
Java基础入门day65
day65 web项目 页面设计 仿照小米官网,将首页保存到本地为一个html页面,再将html页面保存为jsp页面,在项目中的web.xml文件中配置了欢迎页 <welcome-file-list><welcome-file>TypesServlet</welcome-file> </welcome-…...
解密制度的规定和解密工作的具体流程
解密制度是指对于某些敏感的文件或资料,经过一定的时间后,根据相关规定和程序,可以进行解密,解除文件的保密状态,使其可以被公众查阅或利用。解密制度的目的在于确保涉密信息的保密等级与其重要程度相适应,防止涉密信息的泄露和使用不当,同时促进信息公开、传播历史知识…...
实际中常用的网络相关命令
一、ping命令 ping是个使用频率极高的实用程序,主要用于确定网络的连通性。这对确定网络是否正确连接,以及网络连接的状况十分有用。 简单的说,ping就是一个测试程序,如果ping运行正确,大体上就可以排除网络访问层、网…...
机器学习补充
一、数据抽样 数据预处理阶段:对数据集进行抽样可以帮助减少数据量,加快模型训练的速度/减少计算资源的消耗,特别是当数据集非常庞大时,比如设置sample_rate0.8.平衡数据集:通过抽样平衡正负样本,提升模型…...
机器学习——RNN、LSTM
RNN 特点:输入层是层层相关联的,输入包括上一个隐藏层的输出h1和外界输入x2,然后融合一个张量,通过全连接得到h2,重复 优点:结构简单,参数总量少,在短序列任务上性能好 缺点&#x…...
Java项目学习(员工管理)
新增、员工列表、编辑员工整体代码流程与登录基本一致。 1、新增员工 RestController RequestMapping("/admin/employee")EmployeeController 类中使用了注解 RestController 用于构建 RESTful 风格的 API,其中每个方法的返回值会直接序列化为 JSON 或…...
视觉SLAM14精讲——相机与图像3.3
视觉SLAM14精讲 三维空间刚体运动1.0三维空间刚体运动1.1三维空间刚体运动1.2李群与李代数2.1相机与图像3.1相机与图像3.2 视觉SLAM14精讲——相机与图像3.3 视觉SLAM14精讲相机投影流程双目相机模型 相机投影流程 至此,有关相机三维刚体变换的所有因素已经汇集。…...
【路径规划】基于粒子群结合遗传算法实现机器人栅格地图路径规划
研究方法: 基于粒子群优化算法结合遗传算法的机器人栅格地图路径规划是一种智能算法的应用。它将粒子群优化算法和遗传算法相结合,以寻找最优路径规划解决方案。 研究路线: 理论研究:了解粒子群优化算法和遗传算法的基本原理,并掌握相关的路径规划理论知识。 算法设计:…...
内容安全复习 9 - 身份认证系统攻击与防御
文章目录 基于生物特征的身份认证系统概述基于生物特征的身份认证 人脸活体检测检测方法未解决问题 基于生物特征的身份认证系统概述 作用:判别用户的身份、保障信息系统安全。 是识别操作者身份的过程,要保证其**物理身份(现实࿰…...
Python-gui开发之Pycharm+pyside6/Pyqt6环境搭建
Python-gui开发之Pycharm+pyside6/Pyqt6环境搭建 软件版本一、软件安装1、Python安装2、Pycharm安装3、pyside6或pyqt6安装①安装pyside6②安装PyQt6和pyqt6-tools二、Pycharm项目配置1、插件安装2、新建项目以及环境配置3、包管理安装三、在Pycharm中配置PySide61、pyside6 Qt…...
大数据开发语言Scala入门 ,如何入门?
Ai文章推荐 1 作为程序员,开发用过最好用的AI工具有哪些? 2 Github Copilot正版的激活成功,终于可以chat了 3 idea,pycharm等的ai assistant已成功激活 4 新手如何拿捏 Github Copilot AI助手,帮助你提高写代码效率 5 Jetbrains的…...
【人机交互 复习】第1章 人机交互概述
人机交互的知识点碎,而且都是文字,过一遍脑子里什么都留不下,但是背时间已经来不及了,最好还是找题要题感吧,加深印象才是做对文科的关键 一、概念 1.人机交互(Human-Computer Interaction,HCI)࿱…...
HCIP-HarmonyOS Device Developer 课程大纲
一:系统及应用场景介绍 1 -(3 课时) - HarmonyOS 系统介绍;HarmonyOs 定义;HarmonyOS 特征; - 统一 OS,弹性部署;硬件互助,资源共享;一次开发,多…...
Android Wi-Fi 连接失败日志分析
1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分: 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析: CTR…...
Prompt Tuning、P-Tuning、Prefix Tuning的区别
一、Prompt Tuning、P-Tuning、Prefix Tuning的区别 1. Prompt Tuning(提示调优) 核心思想:固定预训练模型参数,仅学习额外的连续提示向量(通常是嵌入层的一部分)。实现方式:在输入文本前添加可训练的连续向量(软提示),模型只更新这些提示参数。优势:参数量少(仅提…...
DAY 47
三、通道注意力 3.1 通道注意力的定义 # 新增:通道注意力模块(SE模块) class ChannelAttention(nn.Module):"""通道注意力模块(Squeeze-and-Excitation)"""def __init__(self, in_channels, reduction_rat…...
解锁数据库简洁之道:FastAPI与SQLModel实战指南
在构建现代Web应用程序时,与数据库的交互无疑是核心环节。虽然传统的数据库操作方式(如直接编写SQL语句与psycopg2交互)赋予了我们精细的控制权,但在面对日益复杂的业务逻辑和快速迭代的需求时,这种方式的开发效率和可…...
linux arm系统烧录
1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 (忘了有没有这步了 估计有) 刷机程序 和 镜像 就不提供了。要刷的时…...
vue3 定时器-定义全局方法 vue+ts
1.创建ts文件 路径:src/utils/timer.ts 完整代码: import { onUnmounted } from vuetype TimerCallback (...args: any[]) > voidexport function useGlobalTimer() {const timers: Map<number, NodeJS.Timeout> new Map()// 创建定时器con…...
GitHub 趋势日报 (2025年06月08日)
📊 由 TrendForge 系统生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日获星趋势图 今日获星趋势图 884 cognee 566 dify 414 HumanSystemOptimization 414 omni-tools 321 note-gen …...
深入解析C++中的extern关键字:跨文件共享变量与函数的终极指南
🚀 C extern 关键字深度解析:跨文件编程的终极指南 📅 更新时间:2025年6月5日 🏷️ 标签:C | extern关键字 | 多文件编程 | 链接与声明 | 现代C 文章目录 前言🔥一、extern 是什么?&…...
聊一聊接口测试的意义有哪些?
目录 一、隔离性 & 早期测试 二、保障系统集成质量 三、验证业务逻辑的核心层 四、提升测试效率与覆盖度 五、系统稳定性的守护者 六、驱动团队协作与契约管理 七、性能与扩展性的前置评估 八、持续交付的核心支撑 接口测试的意义可以从四个维度展开,首…...
如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...
