4.JVM-垃圾回收介绍

news2025/3/19 3:19:30

记录个人学习中记录笔记,如有错误请您指正,谢谢🙏

垃圾回收器发展史

传统垃圾回收: 分代回收 不同代有不同的垃圾回收机制

保底

标记清除算法

垃圾识别算法

引用计数法

缺陷:下图2 出现循环引用 无法解决

可达性分析

大部分(Java,python,go等)都在用这种方式

常见的根对象(GCRoots):

  • 方法区中的常量引用的对象
  • 方法区中的类静态属性引用的对象
  • 本地方法栈中JNI的引用的对象
  • 虚拟机栈(栈帧中的本地变量表)中引用的对象

垃圾清除算法

标记-清除法 (基本不用)

问题: 容易产生无法使用的内存碎片

比如标记可用块每块2MB,实际使用1.9MB,剩余0.1MB就是内存碎片,无法处理

复制法 (适合新生代)

问题:浪费内存空间

存货对象少垃圾对象多的前提下效果好

标记-压缩算法 (适合老年代)

问题:速度慢

三种清除方法比较

新生代垃圾回收器

GC日志内容

/**
 *  jdk17: -Xlog:gc*=info:stdout:time,uptime,level,tags
 *  jdk8:
 *  -Xmx20M
 * -Xmn10M
 * -XX:+PrintGCDetails
 * -XX:+UseSerialGC
 * -XX:+PrintGCTimeStamps
 *  -XX:+PrintGCDateStamps   # 绝对时间
 * -XX:SurvivorRatio=8
 */
public class GC_Serial {
    /*
      -Xmx20M
      -Xmn10M
      -XX:+PrintGCDetails
     -XX:+UseSerialGC
     -XX:+PrintGCTimeStamps
      -XX:SurvivorRatio=8
     */

    private static final int size = 1024 * 256;
    public static void main(String[] args) {
//        System.gc();
        for (int i = 0; i < 30; i++) {
            byte[] date = new byte[size];
        }
    }
    /**
     * Allocation Failure:  // 分配内存失败
     * metadata space exhausted:  // 元数据空间耗尽
     * system.gc() invoked:  // 调用了System.gc() => full gc
     */
    /**
     * 各种垃圾回收器常见的类型:
     * serial => DefNew
     * parNew => ParNew
     * Parallel => PSYoungGen
     * Parallel Old => ParoldGen
     */


}

  • def new generation:新生代
  • tenured generation:老年代
  • metaspace:元空间
    • committed:下次分配可以分配多大空间
    • reserved:最大可用空间多大
0.709: [GC (Allocation Failure) 0.709: [DefNew: 8153K->731K(9216K), 0.0017122 secs] 8153K->731K(19456K), 0.0018048 secs] [Times: user=0.00 sys=0.00, real=0.00 secs] 
Heap
 def new generation   total 9216K, used 3021K [0x00000000fec00000, 0x00000000ff600000, 0x00000000ff600000)
  eden space 8192K,  27% used [0x00000000fec00000, 0x00000000fee3c460, 0x00000000ff400000)
  from space 1024K,  71% used [0x00000000ff500000, 0x00000000ff5b6fc8, 0x00000000ff600000)
  to   space 1024K,   0% used [0x00000000ff400000, 0x00000000ff400000, 0x00000000ff500000)
 tenured generation   total 10240K, used 0K [0x00000000ff600000, 0x0000000100000000, 0x0000000100000000)
   the space 10240K,   0% used [0x00000000ff600000, 0x00000000ff600000, 0x00000000ff600200, 0x0000000100000000)
 Metaspace       used 3226K, capacity 4486K, committed 4864K, reserved 1056768K
  class space    used 332K, capacity 386K, committed 512K, reserved 1048576K

Serial串行回收器-最基本的垃圾回收器

  • 新生代 SerialNew 老年代 SerialOld
  • 新生代使用<font style="background-color:#FBDE28;">复制算法</font> 老年代采用 <font style="background-color:#FBDE28;">标记压缩</font>

测试代码

    /*
      -Xmx20M
      -Xmn10M
      -XX:+PrintGCDetails
     -XX:+UseSerialGC
     -XX:+PrintGCTimeStamps
      -XX:SurvivorRatio=8
     */

    private static final int size = 1024 * 256;
    public static void main(String[] args) {
//        System.gc();
        for (int i = 0; i < 30; i++) {
            byte[] date = new byte[size];
        }
    }
    /**
     * Allocation Failure:  // 分配内存失败
     * metadata space exhausted:  // 元数据空间耗尽
     * system.gc() invoked:  // 调用了System.gc() => full gc
     */
    /**
     * 各种垃圾回收器常见的类型:
     * serial => DefNew
     * parNew => ParNew
     * Parallel => PSYoungGen
     * Parallel Old => ParoldGen
     */

  • def new generation:新生代
  • tenured generation:老年代
  • metaspace:元空间
    • committed:下次分配可以分配多大空间
    • reserved:最大可用空间多大
0.709: [GC (Allocation Failure) 0.709: [DefNew: 8153K->731K(9216K), 0.0017122 secs] 8153K->731K(19456K), 0.0018048 secs] [Times: user=0.00 sys=0.00, real=0.00 secs] 
Heap
 def new generation   total 9216K, used 3021K [0x00000000fec00000, 0x00000000ff600000, 0x00000000ff600000)
  eden space 8192K,  27% used [0x00000000fec00000, 0x00000000fee3c460, 0x00000000ff400000)
  from space 1024K,  71% used [0x00000000ff500000, 0x00000000ff5b6fc8, 0x00000000ff600000)
  to   space 1024K,   0% used [0x00000000ff400000, 0x00000000ff400000, 0x00000000ff500000)
 tenured generation   total 10240K, used 0K [0x00000000ff600000, 0x0000000100000000, 0x0000000100000000)
   the space 10240K,   0% used [0x00000000ff600000, 0x00000000ff600000, 0x00000000ff600200, 0x0000000100000000)
 Metaspace       used 3226K, capacity 4486K, committed 4864K, reserved 1056768K
  class space    used 332K, capacity 386K, committed 512K, reserved 1048576K

ParNew回收器

  • 只能在新生代使用,一般配合老年代 CMS 回收器,比Serial多了并行回收

测试代码
   /*
      -Xmx20M
      -Xmn10M
      -XX:+PrintGCDetails
     -XX:+UseParNew
     -XX:+PrintGCTimeStamps
      -XX:SurvivorRatio=8
     */

    private static final int size = 1024 * 256;
    public static void main(String[] args) {
//        System.gc();
        for (int i = 0; i < 30; i++) {
            byte[] date = new byte[size];
        }
    }
    /**
     * Allocation Failure:  // 分配内存失败
     * metadata space exhausted:  // 元数据空间耗尽
     * system.gc() invoked:  // 调用了System.gc() => full gc
     */
    /**
     * 各种垃圾回收器常见的类型:
     * serial => DefNew
     * parNew => ParNew
     * Parallel => PSYoungGen
     * Parallel Old => ParoldGen
     */


Parallel回收器

JDK8默认的回收器

  • Paralle和ParNew机制类似,通过自适应调节来决定回收时机、和回收频率,达到“吞吐量”有限
  • 和ParNew的区别在于,进入“SafePoints”的时机不一样
  • 在年轻代叫做ParalleNew 老年代叫做 ParalleOld

老年代垃圾回收期

Parallel Old:3.4部分介绍

Serial Old:3.2部分介绍

CMS回收器

没有一个jdk版本设置他默认清理器

JDK14已经移除

优点:

  • 并发收集
  • 停顿时间短

缺点:

  • **处理器资源非常敏感: **收集过程中会开启多个线程
  • 产生浮动垃圾:在并发标记和并发清理阶段,用户线程产生的新垃圾,可能出现Concurrent Model Failure失败而导致另一次Fu GC的产生
  • 空间碎片过多:因为采用的标记清除算法,会产生标记清除算法的问题

初始标记(step-1)

会STW

并发标记(step-2)

重新标记(step-3)

会STW

并发清除(step-4)

CMS 回收过程

初始标记

新生代引用的老年代的活的对象

并发标记

标记第一步找出的GC Roots节点,往下遍历

预清理阶段

将第一步第二步没有引用的节点提前标记,本质第一步第二步的增量操作

为的是减少重新标记的时间

可中断的预处理

把重新标记的工作提前做

重新标记

DirtyCard: 预清理阶段,检查看看是否需要清理

并发清理

并发重置

其他问题

MinorGC vs YoungGC

一样的概念,都是针对 年轻代或者叫做新生代的清理

FullGC vs OldGC

G1之前两者都是一样的,都是老年代的垃圾回收

FullGC 表示 新生代老年代永久代的清理更合理

MajorGC

含义不清

FullGC什么时候出发

System.gc()

手动触发FullGC

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Redis-锁-商品秒杀防止超卖

一、秒杀&#xff08;Seckill&#xff09;​ 1. ​定义 ​秒杀&#xff1a;短时间内&#xff08;如1秒内&#xff09;大量用户同时抢购 ​限量低价商品 的营销活动。​典型场景&#xff1a;双11热门商品抢购、小米手机首发、演唱会门票开售。 2. ​技术挑战 挑战点说明后果…

第一个vue项目

项目目录 启动vue项目 npm run serve 1.vue.config.js文件 (CLI通过vue-cli-serve启动项目&#xff0c;解析配置配置文件vue-condig-js&#xff09; // vue.config.js //引入path板块&#xff0c;这是Node.js的一个内置模块&#xff0c;用于处理文件路径&#xff0c;这里引用…

基于CNN的多种类蝴蝶图像分类

基于CNN的多种类蝴蝶图像分类&#x1f98b; 基于卷积神经网络对64992786张图像&#xff0c;75种不同类别的蝴蝶进行可视化分析、模型训练及分类展示 导入库 import pandas as pd import os import matplotlib.pyplot as plt import seaborn as sns import numpy as np from …

Unity插件-适用于画面传输的FMETP STREAM使用方法(三)基础使用

目录 一、插件介绍 二、组件介绍 三、Game View Streaming 1、使用 FM Network UDP 的基本设置 Server Scene Client Scene 2、使用使用 FM WebSocket 的基本设置 四、Audio Streaming 五、Microphone Streaming 一、插件介绍 ​​​​​​Unity插件-适用于画面传输的…

微信小程序wx.request接口报错(errno: 600001, errMsg: “request:fail -2:net::ERR_FAILED“)

来看看报错 报错如下: 请求发送部分,代码如下: uni.request({url: self.serverUrl "/getRealName",method: GET,data: {"code": self.info.code,},header: {"Authorization": uni.getStorageSync(tokenHead) uni.getStorageSync(token)}}…

基于Python+MySQL编写的(WinForm)图书管理系统

一、项目需求分析 1.1 项目介绍 项目背景 图书馆管理系统是一些单位不可缺少的部分,书籍是人类不可缺少的精神食粮&#xff0c;尤其对于学校来说&#xff0c;尤其重要。所以图书馆管理系统应该能够为用户提供充足的信息和快捷的查询手段。但一直以来人们使用传统人工的方式管…

[贪心算法] 摆动序列

1.解析 这里我们的贪心体现在&#xff0c;这里我们只需要找到每一个拐点位置的数字即可&#xff0c; 证明&#xff1a; 当我们在A点时&#xff0c;我们下一步的选择有四种 A到D这个线段内的数字&#xff08;不包括D&#xff09;选择D点D到F的点F之后的点 对于A到D来说&#xf…

WPF未来展望:紧跟技术发展趋势,探索新的可能性

WPF未来展望&#xff1a;紧跟技术发展趋势&#xff0c;探索新的可能性 一、前言二、WPF 与.NET 技术的融合发展2.1 拥抱.NET Core2.2 利用.NET 5 及后续版本的新特性 三、WPF 在新兴技术领域的应用拓展3.1 与云计算的结合3.2 融入物联网生态 四、WPF 在用户体验和设计方面的创新…

低空经济腾飞:无人机送货、空中通勤,未来已来

近年来&#xff0c;低空经济逐渐成为社会关注的焦点。从无人机送货到“空中的士”&#xff0c;再到飞行培训的火热进行&#xff0c;低空经济正迎来前所未有的发展机遇。随着技术进步和政策支持&#xff0c;这一曾经看似遥远的未来场景&#xff0c;正逐步变为现实。 低空经济如何…

QT编译器mingw与msvc区别及环境配置

一.QT编译器mingw与msvc主要区别 二.QT开发环境配置 1. MinGW 配置 安装步骤&#xff1a; 通过 Qt 官方安装器 安装时勾选 MinGW 组件&#xff08;如 Qt 6.7.0 MinGW 64-bit&#xff09;。 确保系统环境变量包含 MinGW 的 bin 目录&#xff08;如 C:\Qt\Tools\mingw1120_64…

【css酷炫效果】纯CSS实现进度条加载动画

【css酷炫效果】纯CSS实现进度条加载动画 缘创作背景html结构css样式完整代码基础版进阶版 效果图 通过CSS渐变与背景位移动画&#xff0c;无需JavaScript即可创建流体动态进度条。 想直接拿走的老板&#xff0c;链接放在这里&#xff1a;https://download.csdn.net/download/u…

Feedback-Guided Autonomous Driving

Feedback-Guided Autonomous Driving idea 问题设定&#xff1a;基于 CARLA 的目标驱动导航任务&#xff0c;通过知识蒸馏&#xff0c;利用特权智能体的丰富监督信息训练学生传感器运动策略函数 基于 LLM 的端到端驱动模型&#xff1a;采用 LLaVA 架构并添加航点预测头&#…

图解AUTOSAR_CP_WatchdogDriver

AUTOSAR WatchdogDriver模块详解 AUTOSAR MCAL层看门狗驱动模块详细解析 目录 1. 模块概述2. 架构位置 2.1. 组件架构 3. 主要功能4. API接口5. 配置参数 5.1. 配置模型 6. 错误代码7. 状态管理 7.1. 状态机 8. 处理流程 8.1. 活动流程 9. 操作序列 9.1. 典型操作序列 10. 硬件…

大数据学习(65)- Hue详解

&#x1f34b;&#x1f34b;大数据学习&#x1f34b;&#x1f34b; &#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 用力所能及&#xff0c;改变世界。 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4dd;支持一…

C语言学习笔记(第三部份)

说明&#xff1a;由于所有内容放在一个md文件中会非常卡顿&#xff0c;本文件将接续C_1.md文件的第三部分 整型存储和大小端 引例&#xff1a; int main(void) {// printf("%d\n", SnAdda(2, 5));// PrintDaffodilNum(10000);// PrintRhombus(3);int i 0;int arr[…

深入理解蒸馏、Function Call、React、Prompt 与 Agent

AI基础概念与实操 一、什么是蒸馏二、如何理解Function Call、React、Prompt与Agent&#xff08;一&#xff09;Function Call与Agent&#xff08;二&#xff09;Agent中的React概念&#xff08;三&#xff09;Prompt与Agent的关联 实操演练function callprompt 一、什么是蒸馏…

记录一个SQL自动执行的html页面

在实际工作场景中&#xff0c;需要运用到大量SQL语句更新业务逻辑&#xff0c;对程序员本身&#xff0c;写好的sql语句执行没有多大问题&#xff08;图1&#xff09;&#xff0c;但是对于普通用户来说还是有操作难度的。因此我们需要构建一个HTML页面&#xff08;图2&#xff0…

qt介绍图表 charts 一

qt chartsj基于Q的Graphics View框架&#xff0c;其核心组件是QChartView和QChart.QChartView是一个显示图表的独立部件&#xff0c;基类为QGraphicsView.QChar类管理图表的序列&#xff0c;图例和轴示意图。 绘制一个cos和sin曲线图&#xff0c;效果如下 实现代码 #include…

Transformer:GPT背后的造脑工程全解析(含手搓过程)

Transformer&#xff1a;GPT背后的"造脑工程"全解析&#xff08;含手搓过程&#xff09; Transformer 是人工智能领域的革命性架构&#xff0c;通过自注意力机制让模型像人类一样"全局理解"上下文关系。它摒弃传统循环结构&#xff0c;采用并行计算实现高…

S32K144入门笔记(十):TRGMUX的初始化

目录 1. 概述 2. 代码配置 1. 概述 书接上回&#xff0c;TRGMUX本质上是一个多路选择开关&#xff0c;根据用户手册中的描述&#xff0c;它可以实现多个输入的选择输出&#xff0c;本篇文章将验证如何通过配置工具来生成初始化配置代码。 2. 代码配置 笔者通过配置TRGMUX实现…