jvm的垃圾回收器以及触发full gc的场景

JVM(Java虚拟机)的垃圾回收器有很多种,主要包括以下几种:

  1. Serial收集器:串行收集器是最古老、最稳定的收集器。它使用单个线程进行垃圾收集工作,在进行垃圾回收时会暂停所有用户线程。

  2. ParNew收集器:ParNew是Serial收集器的多线程版本,也被称为"并行年轻代收集器",可以与CMS收集器配合使用。

  3. Parallel收集器:Parallel收集器是一种多线程并行的垃圾收集器,用于新生代和老年代的回收。

  4. CMS收集器:CMS(Concurrent Mark-Sweep)收集器是一种以获取最短回收停顿时间为目标的收集器,主要用于老年代的垃圾回收。

  5. G1收集器:G1(Garbage-First)收集器是一种面向服务端应用的垃圾收集器,逐步取代CMS收集器,具有更可控的停顿时间和高效的并发能力。

除了上述列出的垃圾回收器之外,还有其他一些实验性质或特定用途的收集器,如ZGC(Z Garbage Collector)和Shenandoah等。不同的垃圾回收器适用于不同的场景和需求,开发人员可以根据应用的特点选择合适的垃圾回收器来优化性能。

Full GC(Full Garbage Collection)是Java中一种对整个堆内存进行清理和整理的操作,它会停止应用程序的所有线程,包括Young Generation和Old Generation的内存区域都会被扫描和回收。Full GC通常发生在以下几种情况下:

  1. 当Eden区满了,并且触发Minor GC后,存活对象无法全部晋升到Survivor区时,会将剩余的对象直接放入老年代,如果老年代空间不足以容纳这些对象,就会触发Full GC。

  2. 在Old Generation中进行大对象分配时,如果无法找到足够的连续空间来分配该大对象,也会触发Full GC。

  3. 永久代(在JDK 8之前)或元空间(在JDK 8及更高版本)内存不足时,可能会触发Full GC。

  4. 显式调用System.gc()方法,通知虚拟机执行Full GC。

  5. CMS(Concurrent Mark-Sweep)垃圾收集器在并发标记阶段出现"Concurrent Mode Failure"时,会导致一次Full GC。

需要注意的是,Full GC的频繁发生会影响系统的性能,因此在实际开发中需要合理设置堆内存大小、优化程序设计以尽量减少Full GC的发生。

-----------想要java、大数据、人工智能 资料的+v-----------


相关推荐
码字的字节4 小时前
深入理解Java内存与运行时机制:从对象内存布局到指针压缩
java·jvm·内存布局·指针压缩
练习时长两年半的程序员小胡5 小时前
JVM 垃圾回收机制全景解析:从对象回收到收集算法
java·jvm·算法·垃圾回收
笑衬人心。5 小时前
JVM 笔记:类加载、内存管理、垃圾收集与垃圾收集器
java·jvm·笔记
2501_920047038 小时前
python-内存管理
开发语言·jvm·python
xzkyd outpaper14 小时前
JVM、Dalvik、ART区别
jvm·dalvik
笠码21 小时前
JVM Java虚拟机
java·开发语言·jvm·垃圾回收
试着21 小时前
零基础学习性能测试第五章:JVM性能分析与调优-垃圾回收器的分类与回收
jvm·学习·零基础·性能测试·垃圾回收器
kk在加油1 天前
全面理解JVM虚拟机
jvm
啊阿狸不会拉杆1 天前
《Java 程序设计》第 7 章 - 继承与多态
java·开发语言·jvm·算法·intellij-idea
淮北4941 天前
C++学习(线程相关)
jvm·学习