垃圾回收(GC)

一、垃圾回收算法

1、可达性分析法

使用可达性分析法判断对象是否可以被回收

将对象分两类:

垃圾回收的根对象(GC Root)和普通对象,即

  • 线程Thread对象,引用线程栈帧中的方法参数、局部变量等。

  • 系统类加载器加载的java.lang.Class对象,引用类中的静态变量。

  • 监视器对象,用来保存同步锁synchronized关键字持有的对象。

  • 本地方法调用时使用的全局对象。

对象与对象之间的引用关系。

2、垃圾回收工作

找到内存中存活的对象,释放不在存活对象的内存,使得程序能再次利用这部分空间。

3、算法类别

标记 - 清除算法 ------ 复制算法 ------ 标记 - 整理算法 ------ 分代GC

4、STW

Java垃圾回收过程会通过单独的GC线程来完成,但是不管使用哪一种GC算法,都会有部分阶段需要停止所有的用户线程。这个过程被称之为Stop The World 简称STW,如果STW时间过长则会影响用户的使用。

5、G1(Garbage First)垃圾回收器

优点:

支持巨大的对空间回收,并且有较高的吞吐量 ②支持多CPU并行垃圾回收 ③允许用户设置最大暂停时间

区域划分

G1的整个堆会被划分成多个大小相等的区域,称之为区Region,区域不要求是连续的。分为Eden(伊甸园区)、Survivor(幸存者区)、Old(老年代)区。Region的大小通过堆空间大小/2048计算得到,也可以通过参数-XX:G1HeapRegionSize=32m指定(其中32m指定region大小为32M),Region size必须是2的指数幂,取值范围从1M到32M。

混合回收

混合回收分为:初始标记(initial mark)、并发标记(concurrent mark)、最终标记(remark或者Finalize Marking)、并发清理(cleanup)

G1对老年代的清理会选择存活度最低的区域来进行回收,这样可以保证回收效率最高。

注意:如果清理过程中发现没有足够的空Region存放转移的对象,会出现Full GC。单线程执行标记-整理算法,此时会导致用户线程的暂停。所以尽量保证应该用的堆内存有一定多余的空间。

设置参数

参数1: -XX:+UseG1GC 打开G1的开关,JDK9之后默认不需要打开

参数2:-XX:MaxGCPauseMillis=毫秒值 最大暂停的时

相关推荐
NGC_6611几秒前
快速排序算法
数据结构·算法·排序算法
七夜zippoe2 分钟前
微服务架构下Spring Session与Redis分布式会话实战全解析
java·redis·maven·spring session·分布式会话
机器视觉的发动机6 分钟前
图像处理-机器视觉算法中的数学基础
开发语言·人工智能·算法·决策树·机器学习·视觉检测·机器视觉
Darkwanderor6 分钟前
离散化思维的应用
数据结构·c++·算法·哈希算法
健忘的派大星2 小时前
需求激增800%!2025年第一硬通货:懂大模型、云计算和硬件的“前沿部署工程师”!
人工智能·算法·架构·langchain·云计算·大模型学习·大模型教程
vx_Biye_Design2 小时前
【关注可免费领取源码】云计算及其应用网络教学系统--毕设附源码35183
java·spring·spring cloud·servlet·eclipse·云计算·课程设计
ShineWinsu8 小时前
对于C++:继承的解析—上
开发语言·数据结构·c++·算法·面试·笔试·继承
pp起床8 小时前
动态规划 | part05
算法·动态规划
GuangHeAI_ATing9 小时前
国密算法SSD怎么选?这3款国产固态硬盘安全又高速
算法
码农阿豪9 小时前
Nacos 日志与 Raft 数据清理指南:如何安全释放磁盘空间
java·安全·nacos