JVM垃圾回收器

简介: JVM垃圾回收器

垃圾回收器(Garbage Collector)是负责执行垃圾回收的组件,它在Java虚拟机中进行自动内存管理。垃圾回收器负责检测无法被访问到的对象,并释放其占用的内存空间。

Java中,有多种不同的垃圾回收器可供选择,每个回收器都有不同的特点和适用场景。以下是常见的几种垃圾回收器:

1.      Serial回收器Serial回收器是最基本的、单线程的垃圾回收器。它通过暂停所有应用线程,进行垃圾回收操作,直到完成为止。Serial回收器适用于单核处理器或小型应用,但在大型应用中可能导致较长的暂停时间。

Serial 作用于新生代,采用复制算法

-Serial Old作用于老年代,采用标记-整理算法

2.      Parallel回收器Parallel回收器是Serial回收器的多线程版本,它使用多个线程并行执行垃圾回收操作。Parallel回收器适用于具有多个处理器核心且希望实现更高吞吐量的系统,但仍可能导致较长的暂停时间。**JDK8默认使用此垃圾回收器**

Parallel New作用于新生代,采用复制算法

Parallel Old作用于老年代,采用标记-整理算法

3.      CMS回收器CMSConcurrent Mark Sweep)回收器是一种并发的垃圾回收器,它通过与应用程序并发执行,减少垃圾回收过程中的停顿时间。CMS回收器适用于具有较短暂停时间要求的应用程序,但在处理大量垃圾对象时会产生内存碎片。

4.      G1回收器G1Garbage-First)回收器是一种面向服务端应用的垃圾回收器,它采用了分区和并发的方式来管理堆内存。G1回收器旨在提供可预测的短暂停时间,并有效地处理大堆内存。G1回收器可以根据应用程序的需求动态调整可用内存和停顿时间目标。--JDK9之后默认使用G1

其主要特点:

·        应用于新生代和老年代

·        划分成多个区域,每个区域都可以充当 edensurvivorold humongous,其中 humongous 专为大对象准备

·        采用复制算法

·        响应时间与吞吐量兼顾

·        分成三个阶段:新生代回收、并发标记、混合收集

·        如果并发失败(即回收速度赶不上创建新对象速度),会触发 Full GC

 

除了上述的垃圾回收器,还有其他一些特定用途或实验性质的回收器,如ZGCZ Garbage Collector)、ShenandoahEpsilon 等。这些回收器有着不同的特点和适用场景,可以根据具体应用程序的需求进行选择和配置。

需要注意的是,不同的垃圾回收器在性能、吞吐量、延迟等方面有所差异,开发人员可以根据应用程序的特点和需求选择合适的垃圾回收器,并通过调整JVM参数来优化垃圾回收的行为。

 

相关文章
|
4月前
|
Arthas 存储 算法
深入理解JVM,包含字节码文件,内存结构,垃圾回收,类的声明周期,类加载器
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析类加载器的定义:JVM提供类加载器给Java程序去获取类和接口字节码数据类加载器的作用:类加载器接受字节码文件。
443 55
|
9月前
|
监控 算法 Java
Java虚拟机(JVM)垃圾回收机制深度剖析与优化策略####
本文作为一篇技术性文章,深入探讨了Java虚拟机(JVM)中垃圾回收的工作原理,详细分析了标记-清除、复制算法、标记-压缩及分代收集等主流垃圾回收算法的特点和适用场景。通过实际案例,展示了不同GC(Garbage Collector)算法在应用中的表现差异,并针对大型应用提出了一系列优化策略,包括选择合适的GC算法、调整堆内存大小、并行与并发GC调优等,旨在帮助开发者更好地理解和优化Java应用的性能。 ####
227 27
|
10月前
|
监控 算法 Java
Java虚拟机(JVM)的垃圾回收机制深度解析####
本文深入探讨了Java虚拟机(JVM)的垃圾回收机制,旨在揭示其背后的工作原理与优化策略。我们将从垃圾回收的基本概念入手,逐步剖析标记-清除、复制算法、标记-整理等主流垃圾回收算法的原理与实现细节。通过对比不同算法的优缺点及适用场景,为开发者提供优化Java应用性能与内存管理的实践指南。 ####
|
4月前
|
缓存 算法 Java
JVM深入原理(八)(一):垃圾回收
弱引用-作用:JVM中使用WeakReference对象来实现软引用,一般在ThreadLocal中,当进行垃圾回收时,被弱引用对象引用的对象就直接被回收.软引用-作用:JVM中使用SoftReference对象来实现软引用,一般在缓存中使用,当程序内存不足时,被引用的对象就会被回收.强引用-作用:可达性算法描述的根对象引用普通对象的引用,指的就是强引用,只要有这层关系存在,被引用的对象就会不被垃圾回收。引用计数法-缺点:如果两个对象循环引用,而又没有其他的对象来引用它们,这样就造成垃圾堆积。
139 0
|
4月前
|
算法 Java 对象存储
JVM深入原理(八)(二):垃圾回收
Java垃圾回收过程会通过单独的GC线程来完成,但是不管使用哪一种GC算法,都会有部分阶段需要停止所有的用户线程。这个过程被称之为StopTheWorld简称STW,如果STW时间过长则会影响用户的使用。一般来说,堆内存越大,最大STW就越长,想减少最大STW,就会减少吞吐量,不同的GC算法适用于不同的场景。分代回收算法将整个堆中的区域划分为新生代和老年代。--超过新生代大小的大对象会直接晋升到老年代。
97 0
|
6月前
|
缓存 监控 算法
JVM简介—2.垃圾回收器和内存分配策略
本文介绍了Java垃圾回收机制的多个方面,包括垃圾回收概述、对象存活判断、引用类型介绍、垃圾收集算法、垃圾收集器设计、具体垃圾回收器详情、Stop The World现象、内存分配与回收策略、新生代配置演示、内存泄漏和溢出问题以及JDK提供的相关工具。
JVM简介—2.垃圾回收器和内存分配策略
|
10月前
|
机器学习/深度学习 监控 算法
Java虚拟机(JVM)的垃圾回收机制深度剖析####
本文深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法、性能调优策略及未来趋势。通过实例解析,为开发者提供优化Java应用性能的思路与方法。 ####
226 28
|
9月前
|
算法 网络协议 Java
【JVM】——GC垃圾回收机制(图解通俗易懂)
GC垃圾回收,标识出垃圾(计数机制、可达性分析)内存释放机制(标记清除、复制算法、标记整理、分代回收)
|
9月前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
10月前
|
监控 算法 Java
Java虚拟机垃圾回收机制深度剖析与优化策略####
【10月更文挑战第21天】 本文旨在深入探讨Java虚拟机(JVM)中的垃圾回收机制,揭示其工作原理、常见算法及参数调优技巧。通过案例分析,展示如何根据应用特性调整GC策略,以提升Java应用的性能和稳定性,为开发者提供实战中的优化指南。 ####
127 5