JVM垃圾回收器详解:串行回收新生代内存管理垃圾回收的触发机制

简介: 在讨论新生代垃圾回收之前,首先要解决的问题就是:谁能触发垃圾回收?何时触发垃圾回收?从垃圾回收的角度来说,既可以进行主动回收,也可以进行被动回收。

垃圾回收的触发机制

在讨论新生代垃圾回收之前,首先要解决的问题就是:谁能触发垃圾回收?何时触发垃圾回收?

从垃圾回收的角度来说,既可以进行主动回收,也可以进行被动回收。

主动回收指的是GC工作线程发现内存不足时主动发起垃圾回收动作,被动回收指的是Mutator在对象分配的时候发现内存不足,由Mutator触发GC工作线程执行垃圾回收动作。主动进行回收需要额外的处理,判断何时启动垃圾回收,实现比较复杂;被动回收则非常简单。串行回收选择被动回收。

垃圾回收的执行可以由专门的GC工作线程来执行,也可以由Mutator来执行。通常来说,Mutator用于执行应用业务,如果把垃圾回收的工作放在Mutator中执行,会导致JVM设计的复杂性。使用专门的GC工作线程来执行垃圾回收工作的方法更为常见。GC工作线程执行垃圾回收时需要应用暂停(即STW),在JVM中最新的垃圾回收器实现或者增强中为了减少STW的时间,会把垃圾回收的一些任务放入Mutator中执行,也就是后面介绍的并发垃圾回收。

目前JVM中所有垃圾回收的触发机制有3种方式,即串行回收,并行回收和主动回收,如图3-9~图3-11所示。

网络异常,图片无法展示
|

图3-9 被动回收之串行回收

图3-9和图3-10演示的是被动回收。其中,图3-9中VMThread作为GC工作线程执行垃圾回收;图3-10中VMThread作为控制线程启动多个GC工作线程并行执行垃圾回收。图3-11演示的是主动回收。串行回收中Minor GC采用的是图3-9的触发机制方式,Parallel GC、ParNew、G1中Minor GC采用的是图3-10的触发机制方式,ZGC和Shenandoah采用的是图3-11的触发机制方式。

网络异常,图片无法展示
|

图3-10 被动回收之并行回收

网络异常,图片无法展示
|

图3-11 主动回收

在JVM的串行回收实现中,当Mutator发现无法为对象分配内存空间时,就会请求GC工作线程执行垃圾回收。JVM中被动执行垃圾回收的流程如下:

1)Mutator发现内存空间不足,触发垃圾回收请求。

2)VMThread控制线程接受请求,暂停所有的Mutator,以便响应垃圾回收执行请求。

3)VMThread作为GC工作线程执行垃圾回收动作。

4)VMThread发现垃圾回收动作执行后会唤醒暂停执行的Mutator,Mutator恢复执行。

本文给大家讲解的内容是JVM垃圾回收器详解:串行回收,新生代内存管理垃圾回收的触发机制

相关文章
|
存储 安全 算法
深入剖析JVM内存管理与对象创建原理
JVM内存管理,JVM运行时区域,直接内存,对象创建原理。
45 2
|
11天前
|
算法 Java Go
Go vs Java:内存管理与垃圾回收机制对比
对比了Go和Java的内存管理与垃圾回收机制。Java依赖JVM自动管理内存,使用堆栈内存并采用多种垃圾回收算法,如标记-清除和分代收集。Go则提供更多的手动控制,内存分配与释放由分配器和垃圾回收器协同完成,使用三色标记算法并发回收。示例展示了Java中对象自动创建和销毁,而Go中开发者需注意内存泄漏。选择语言应根据项目需求和技术栈来决定。
|
1天前
|
存储 监控 算法
JVM工作原理与实战(二十七):堆的垃圾回收-G1垃圾回收器
JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了G1垃圾回收器、G1垃圾回收器的回收方式、G1垃圾回收器执行流程、垃圾回收器的选择等内容。
|
1天前
|
机器学习/深度学习 监控 算法
JVM工作原理与实战(二十六):堆的垃圾回收-垃圾回收器
JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了垃圾回收器、Serial垃圾回收器、SerialOld垃圾回收器、ParNew垃圾回收器、CMS垃圾回收器、Parallel Scavenge垃圾回收器、Parallel Old垃圾回收器等内容。
|
1天前
|
监控 安全 Java
JVM工作原理与实战(二十一):内存管理
JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了不同语言的内存管理(C/C++、Java)、垃圾回收的对比(自动垃圾回收与手动垃圾回收)等内容。
|
13天前
|
存储 缓存 NoSQL
Redis 内存回收
Redis 内存回收
15 3
|
22天前
|
存储 缓存 监控
Java内存管理:垃圾回收与内存泄漏
【4月更文挑战第16天】本文探讨了Java的内存管理机制,重点在于垃圾回收和内存泄漏。垃圾回收通过标记-清除过程回收无用对象,Java提供了多种GC类型,如Serial、Parallel、CMS和G1。内存泄漏导致内存无法释放,常见原因包括静态集合、监听器、内部类、未关闭资源和缓存。内存泄漏影响性能,可能导致应用崩溃。避免内存泄漏的策略包括代码审查、使用分析工具、合理设计和及时释放资源。理解这些原理对开发高性能Java应用至关重要。
|
26天前
|
存储 前端开发 安全
JVM内部世界(内存划分,类加载,垃圾回收)(上)
JVM内部世界(内存划分,类加载,垃圾回收)
54 0
|
26天前
|
算法 安全 Java
内存分配与回收策略
内存分配与回收策略
23 0
内存分配与回收策略
|
1月前
|
算法 Java
【JVM系列】你说说都有哪些垃圾回收器
垃圾回收的是新生代、永久代对吧?那永久代还会进行回收吗?会的,永久代里的废弃常量和无用的类会被回收。例如类里面的常量没有其他任何引用,如果发生内存回收,有必要的话会进行。。。
71 5
【JVM系列】你说说都有哪些垃圾回收器