05、GC基础知识

JVM程序在跑起来之后,在数据的交互过程中,就会有一些数据是过期不用的,这些数据可以看做是垃圾,JVM中,这些垃圾是不用开发者管的,它自己会有一套垃圾回收系统自动回收这些内存垃圾,以备后面继续使用。这就是JVM的GC系统。GC这块知识很多,这篇文章主要是了解下它的基本知识点
1、如何定位垃圾
2、GC的回收算法
3、GC的内存分代模型

1、如何定位垃圾

  • 引用计数法:它的核心思想是,没有引用指向的内存区域是垃圾区域,GC可以回收这个区域。具体的做法是,每当有引用指向这个对象,它对应的计数就+1,当有引用取消了对它的指向就-1,如果计数为0的时候,它就会被GC自动回收。
    • 它的问题:引用计数法如果碰到循环引用的垃圾,就会失效。比如a引用b,b也引用a,但是他们整体的引用在程序中已经释放掉了,但是由于它们互相引用,引用计数永远不可能为0,所有它们永远不会被回收。
    • 它的解决方案是如下的“根可达算法”来解决
  • 根可达算法:它的核心思想是,如果一个对象没有根对象直接或间接的指向它,那它就是垃圾。具体的是要弄清楚哪些是属于根对象
    根对象
    • 根对象:
      • JVM Stacks里的对象(线程栈变量)
      • Native Method Stack(本地方法栈的对象)
      • Run-time Constant Pool(常量池里的对象)
      • Static Refercens In Method Area(方法区的静态对象)

      程序跑起来也就是main函数跑起来之后,它里面需要用到的对象都算是根对象,如线程栈变量和本地方法栈变量,然后就是用Static申请的对象,如果是字符串类型那就是常量池数据,如果是静态的引用那就是方法区的对象,这些算是根对象。它们直接或是间接引用的对象都不能算是垃圾。

2、GC回收算法

  • 标记清楚算法
    • 具体实现:第一阶段根据GCRoot规则把存活对象进行标记,第二阶段会清楚掉没有标记的对象
    • 特点:根据它的工作特点可以发现,清除之后留下来的内存不连续,会产生内存碎片。需要经过两次扫描,效率低
    • 使用场景:适用于对象存活时间长的情况,不如old区
  • 拷贝算法
    • 具体实现:首先把内存区域分为两部分A,B区域,一部分空置着(比如B区),等另外一部分(A区)满了之后,直接把A区存活对象复制到B区,然后把A区数据全部清除
    • 特点:内存位置连续,无碎片化,扫描一次即可,但是需要移动和复制内存对象,且浪费空间,有效利用率只有50%
    • 使用场景:适用于对象存活时间短的场景,比如年轻代的from区和to区
  • 标记压缩算法
  • 具体实现:它跟标记清楚算法类似,都需要经过两次扫描,不一样的是,第二阶段并不是删除未标记对象,而是把标记对象压缩到内存的一端,之后清理掉其他的空间
  • 特点:位置连续,没有碎片,内存的利用率也很高,但也是需要两次扫描且需要把对象移动到头部,效率偏低
  • 使用场景:适用于对象存活时间较长的情况,比如old区

3、GC内存分代模型

3.1、常见的GC,以及他们之间的组合

GC类型

Serial系列的GC是最早版本的,它都是单线程串行回收垃圾,一般针对几十兆内存的机器

  • Serial:底层用的是复制算法+单线程,用于年轻代回收
  • Serial Old:底层用的是标记压缩算法+但线程,用于老年代回收

PS+PO算法是JDK1.8版本以及之前版本默认的GC,他们都是并行回收的,一般能回收几个G的内存数据

  • Parallel Scavenge:拷贝算法+并行,用于年轻代
  • Parallel Old:标记清除算法+并行,用于老年代

PN+CMS算法是较新的一种组合,它们是期望用于更大内存的回收,其中PN算法是配合CMS对年轻代回收的一种算法

  • ParNew:拷贝算法+并行计算
  • CMS:三色标记算法+并行计算
  • G1,ZGC,Shenandoah:这些都是新一代的GC,后面会具体篇幅专门介绍。

3.2、GC的分代模型

Serial系列,Parallel Scavenge,Parallel Old,ParNew,CMS,这些都是逻辑和物理上都是进行分代的,G1是逻辑上分代,但是物理上是不分代的,之后的GC如ZGC,Shenandoah他们逻辑和物理上都不分代。如果分代的话,一般分为年轻代和老年代,他们默认的占比是New:Old=1:2

  • 年轻代:Eden+2个Survival区(from+to区),它们内存占比默认是8:1:1,其中一个区域满了就会触发YGC。from区和to区一般只有一个区域是在使用的
  • 老年代:垃圾相对于较少,如果满了之后会触发FullGC
3.2.1、对象在各个分代区域的流转规则
  • Young区的数据流转

在Young区,如果Eden区满了,就会触发YGC,就会把Eden区存活的对象复制到from区,然后清除掉Eden,如果from区满了,会把数据复制到to区,清除掉from,Young区的流转大致如上所述。

  • Old区的数据流转

Old 区的数据都是从Young流转过来的,具体的流转条件如下所述

  • 大对象直接进入Old区(通过GC参数-XX:+MaxTenuringThreshold 来设定)
  • 动态年龄:如年龄1的占33%,年龄2的占33%,年龄3的占34%,年龄2+年龄3>50%,所以年龄2,3的对象同时晋升到old区
  • 分配担保:YGC期间Survivor区空间不够时,担保的空间直接进入Old区
  • age年龄到了15岁时会进入Old区

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

苍穹外卖-day05redis 缓存的学习

苍穹外卖-day05 课程内容 Redis入门Redis数据类型Redis常用命令在Java中操作Redis店铺营业状态设置 学习目标 了解Redis的作用和安装过程 掌握Redis常用的数据类型 掌握Redis常用命令的使用 能够使用Spring Data Redis相关API操作Redis 能够开发店铺营业状态功能代码 功能实…

Spark-Streaming集成Kafka

Spark Streaming集成Kafka是生产上最多的方式,其中集成Kafka 0.10是较为简单的,即:Kafka分区和Spark分区之间是1:1的对应关系,以及对偏移量和元数据的访问。与高版本的Kafka Consumer API 集成时做了一些调整,下面我们…

启动报错java.lang.NoClassDefFoundError: ch/qos/logback/core/status/WarnStatus

报错信息图片 日志: Exception in thread "Quartz Scheduler [scheduler]" java.lang.NoClassDefFoundError: ch/qos/logback/core/status/WarnStatus先说我自己遇到的问题,我们项目在web设置了自定义的log输出路径,多了一个 / 去…

2025erp系统开源免费进销存系统搭建教程/功能介绍/上线即可运营软件平台源码

系统介绍 基于ThinkPHP与LayUI构建的全方位进销存解决方案 本系统集成了采购、销售、零售、多仓库管理、财务管理等核心功能模块,旨在为企业提供一站式进销存管理体验。借助详尽的报表分析和灵活的设置选项,企业可实现精细化管理,提升运营效…

数据增强的几大方式

1. 随机擦除(Random Erasing) 说明 随机在图像中选取一个矩形区域,将其像素值随机化或设为零,以增加模型对部分缺失信息的鲁棒性。 import numpy as np import cv2def random_erasing(image, sl0.02, sh0.2, r10.3):h, w, _ image.shapearea h * wta…

leecode416.分割等和子集

这道题目看了题解把题目转化为01背包问题才恍然大悟,sum为数组的总和,背包容量为sum/2,价值和背包重量都为nums[i],由于价值和背包重量都为nums[i],那么容量为sum/2的背包最多只能获得最大的价值是sum/2,所…

首次下载steam更新速度慢解决方法

下载免费的加速器,在加速器的steam商店加速页面→加速后页面上方的区服选择 (香港移动)→双箭头→改为登录异常专用→在下部的登录修复进入steam更新 就好了,亲测有效

芯片级IO (Pad) Ring IP Checklist

SoC top顶层数字后端实现都会涉及到IO Ring (PAD Ring)的设计。这里面包括VDD IO,VDDIO IO, Signal IO, Corner IO,Filler IO,IO power cut cell等等。 数字后端零基础入门系列 | Innovus零基础LAB学习Day2 数字IC后端实现TOP F…

通过算法识别运行过程中产生的常见缺陷,及时处理,避免运行故障,影响正常作业的智慧快消开源了

智慧快消视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。 基于多年的深度…

μC/OS-Ⅱ源码学习(7)---软件定时器

快速回顾 μC/OS-Ⅱ中的多任务 μC/OS-Ⅱ源码学习(1)---多任务系统的实现 μC/OS-Ⅱ源码学习(2)---多任务系统的实现(下) μC/OS-Ⅱ源码学习(3)---事件模型 μC/OS-Ⅱ源码学习(4)---信号量 μC/OS-Ⅱ源码学习(5)---消息队列 μC/OS-Ⅱ源码学习(6)---事件标志组 本文进一…

CRYPTO密码学

加解密算法/编码 编码base家族unicodeASCII哈希算法MD5 Message Digest AlgorithmnSM3SHA-3GBGB18030GB2312GBKutf家族恺撒二进制分区法DSADSSCRC32校验对称非对称gbk编码h264SEA初探smc动态代码保护四方密码曼彻斯特编码剖析基本概念什么是编码?什么是加密与解密寻找银弹-有没…

【前端】深入探讨 JavaScript 的 reduce() 方法

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: 前端 文章目录 💯前言💯什么是 reduce() 方法?定义与核心概念语法结构参数解析返回值 💯基础用法与示例示例 1:计算数组元素的和解析 示例 2:统计…

postman关联接口用于登录(验证码会变情况)

目录 一、介绍 二、操作步骤 (一)Fiddler抓取到登录信息 (二)postman发送请求 新建请求一:登录值请求 (三)易变值赋值固定住 新建请求二:易变值验证码(uuid)请求 切换到请求一里面进行赋值绑定 一、介绍 接口有两种形式,一种是单…

SSC338Q SigmaStar 摄像头主控芯片

SSC338Q 是一款由 SigmaStar(星宸科技)推出的高集成度多媒体系统级芯片(SoC),广泛应用于高分辨率智能视频录制设备,如 IP 摄像机、车载摄像机和 USB 摄像机。 处理器: CPU:32 位双…

苹果将推出超薄和折叠款iPhone,2024年带来哪些变化?

苹果公司(AAPL)近日宣布,将对其iPhone系列进行重大升级,以应对当前市场中的销量压力。这一改变,或许会为苹果带来新的增长动力。那么,苹果的2024年新iPhone究竟有哪些亮点呢?下面我们来详细了解…

QML 粒子模拟

粒子模拟 粒子模拟 粒子模拟的核心是粒子系统(ParticleSystem), 它控制共享时间线。一个粒子使用发射器元素(Emitter)发射, 使用粒子画笔(ParticlePainter)实现可视化, 它可以是一张…

Java中的Consumer接口应该如何使用(通俗易懂图解)

应用场景: 第一次程序员A写好了个基础的遍历方法: public class Demo1 {public static void main(String[] args) {//假设main方法为程序员B写的,此时需要去调用A写好的一个遍历方法//1.如果此时B突然发现想将字符串以小写的形式打印出来,则…

WPF+MVVM案例实战与特效(四十四)- WPF多语言支持全解析:轻松实现国际化应用

文章目录 1、引言2、案例效果3、准备工作1、创建项目结构2、代码实现1、语言资源2、资源引用3、页面功能4、实现效果3、总结1、引言 在当今全球化的背景下,开发一个多语言支持的应用程序变得越来越重要。WPF提供了强大的功能来实现应用程序的国际化和本地化。本文将详细介绍如…

Java爬虫大冒险:如何征服1688商品搜索之巅

在这个信息爆炸的时代,数据就是力量。对于电商平台而言,数据更是金矿。今天,我们要踏上一场Java爬虫的冒险之旅,目标是征服1688这个B2B电商巨头,获取按关键字搜索的商品信息。这不仅是技术的挑战,更是智慧的…

《Django 5 By Example》读后感

一、 为什么选择这本书? 本人的工作方向为Python Web方向,想了解下今年该方向有哪些新书出版,遂上packt出版社网站上看了看,发现这本书出版时间比较新(2024年9月),那就它了。 从2024年11月11日至2024年12月18日期间&…