JVM系列(十):JVM垃圾回收算法相关知识

简介: JVM垃圾回收算法主要有标记清除、复制算法、标记整理、分代收集四种,下面来逐一介绍。

image_78401815.png

今天给大家继续分享JVM垃圾回收算法相关知识,如有不对的地方欢迎指正。

JVM垃圾回收算法主要有标记清除、复制算法、标记整理、分代收集四种,下面来逐一介绍。

1、标记清除(Mark-Sweep)

image_1539b2ad.png

标记清除作为最基础的垃圾回收算法,其过程要经历两个阶段:标记、回收。

标记:遍历内存区域,标记出待回收的对象。

回收:再次遍历内存区域,然后对已标记的对象占用的内存进行回收。

缺点:

  • 需要遍历两次内存区域,效率低。
  • 因为JVM存储特点是逻辑上连续,物理上可以不连续,标记清除算法可能产生大量内存碎片,当JVM需要一块比较大的内存空间的时候,而又找不到合适的内存空间,就会触发下一次的垃圾回收操作。

2、复制算法(Copy)

image_ce775553.png

复制算法主要是解决标记—清除算法遍历的和产生内存碎片的缺点,在其基础上进行改进而来的,它会将可用内存按容量分为大小相等的两块,每次只能使用其中的一块,当正在使用的这一块的内存空间不满足使用的时候,就会将还存活的对象复制到另外一块空的内存上面,然后再把当前内存空间一次清理掉。

复制算法在新生代中两个幸存区(From 、To)的不停交换是最典型的用法,

新生代内存空间占比为 8(Eden 伊甸园区 ):1 (To Survivor):1 (Survivor From)。

优点

  • 内存回收时,不会产生内存碎片
  • 回收的时候只需移动栈顶指针,按顺序分配内存即可,实现简单
  • 每次只对两块中的一块内存进行回收,效率高
  • 复制算法执行后,空间时连续的。

缺点

一次性分配内存只能用其中的一半,内存的最大可利用率只有一半。

3、标记整理(Mark-Compact)

image_26b77207.png

标记整理算法主要是针对老年代来设计的。

执行过程

  • 标记:对需要回收对象的进行标记
  • 整理:让存活的对象,向内存的一端移动,在整理的过程中,之前对象的在虚拟机栈中的引用地址也随之发生改变,最后直接清理掉非存活对象的内存空间。

优点

  • 没有碎片化内存产生(标记清除算法比较)
  • 没有了内存利用率减半的消耗(复制算法比较)

缺点

  • 效率相比标记复制算法稍低
  • 在整理存活对象过程中,因为存活对象位置点变动,需要调整对象在虚拟机栈中的引用地址,同时需要全程暂停用户线程,STW(Stop The World)

4、分代收集算法

严格意义上来说分代收集不能算一种新的垃圾回收算法,分代收集其实只是根据对象的存活的时间的长短,将新生代和老年代针对不同的内存区域,采取对应的算法。目前市面上大多商用虚拟机都采用分代收集算法,

新生代:每次都有大量对象消亡,因为有老年代作为内存担保,比较采取复制算法。

老年代:对象存活时间长,可采用标记整理、标记清除算法。

5、三种垃圾回收算法对比

对比参数

标记清除

标记整理

标记复制

速度

中等

最慢

最快

空间开销

少(会产生碎片)

少(不会产生碎片)

2倍开销

移动对象

适合场景

老年代

老年代

新生代

相关文章
|
2月前
|
监控 算法 Java
Java虚拟机(JVM)的垃圾回收机制深度解析####
本文深入探讨了Java虚拟机(JVM)的垃圾回收机制,旨在揭示其背后的工作原理与优化策略。我们将从垃圾回收的基本概念入手,逐步剖析标记-清除、复制算法、标记-整理等主流垃圾回收算法的原理与实现细节。通过对比不同算法的优缺点及适用场景,为开发者提供优化Java应用性能与内存管理的实践指南。 ####
|
1月前
|
监控 算法 Java
Java虚拟机(JVM)垃圾回收机制深度剖析与优化策略####
本文作为一篇技术性文章,深入探讨了Java虚拟机(JVM)中垃圾回收的工作原理,详细分析了标记-清除、复制算法、标记-压缩及分代收集等主流垃圾回收算法的特点和适用场景。通过实际案例,展示了不同GC(Garbage Collector)算法在应用中的表现差异,并针对大型应用提出了一系列优化策略,包括选择合适的GC算法、调整堆内存大小、并行与并发GC调优等,旨在帮助开发者更好地理解和优化Java应用的性能。 ####
57 0
|
27天前
|
算法 网络协议 Java
【JVM】——GC垃圾回收机制(图解通俗易懂)
GC垃圾回收,标识出垃圾(计数机制、可达性分析)内存释放机制(标记清除、复制算法、标记整理、分代回收)
|
1月前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
2月前
|
机器学习/深度学习 监控 算法
Java虚拟机(JVM)的垃圾回收机制深度剖析####
本文深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法、性能调优策略及未来趋势。通过实例解析,为开发者提供优化Java应用性能的思路与方法。 ####
64 1
|
2月前
|
监控 算法 Java
Java虚拟机垃圾回收机制深度剖析与优化策略####
【10月更文挑战第21天】 本文旨在深入探讨Java虚拟机(JVM)中的垃圾回收机制,揭示其工作原理、常见算法及参数调优技巧。通过案例分析,展示如何根据应用特性调整GC策略,以提升Java应用的性能和稳定性,为开发者提供实战中的优化指南。 ####
50 5
|
2月前
|
存储 算法 安全
JVM常见面试题(四):垃圾回收
堆区域划分,对象什么时候可以被垃圾器回收,如何定位垃圾——引用计数法、可达性分析算法,JVM垃圾回收算法——标记清除算法、标记整理算法、复制算法、分代回收算法;JVM垃圾回收器——串行、并行、CMS垃圾回收器、G1垃圾回收器;强引用、软引用、弱引用、虚引用
|
2月前
|
存储 算法 Java
JVM进阶调优系列(10)敢向stop the world喊卡的G1垃圾回收器 | 有必要讲透
本文详细介绍了G1垃圾回收器的背景、核心原理及其回收过程。G1,即Garbage First,旨在通过将堆内存划分为多个Region来实现低延时的垃圾回收,每个Region可以根据其垃圾回收的价值被优先回收。文章还探讨了G1的Young GC、Mixed GC以及Full GC的具体流程,并列出了G1回收器的核心参数配置,帮助读者更好地理解和优化G1的使用。
|
2月前
|
监控 Java 测试技术
Elasticsearch集群JVM调优垃圾回收器的选择
Elasticsearch集群JVM调优垃圾回收器的选择
75 1
|
3月前
|
缓存 算法 Java
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
141 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS