JVM06_方法区的概述、内部结构、演变、常量池、运行时常量池、垃圾回收(四)

简介: ⑧. 方法区的垃圾回收

⑧. 方法区的垃圾回收


前言:

(1).有些人认为方法区(如Hotspot,虚拟机中的元空间或者永久代)是没有垃


圾收集行为的,其实不然。《Java 虚拟机规范》对方法区的约束是非常宽松


的,提到过可以不要求虚拟机在方法区中实现垃圾收集。事实上也确实有未实


现或未能完整实现方法区类型卸载的收集器存在(如 JDK11 时期的 ZGC 收集


器就不支持类卸载)

(2). 一般来说这个区域的回收效果比较难令人满意,尤其是类型的卸载,条件


相当苛刻。但是这部分区域的回收有时又确实是必要的。以前 Sun 公司的


Bug 列表中,曾出现过的若干个严重的 Bug 就是由于低版本的 Hotspot 虚拟


机对此区域未完全回收而导致内存泄漏。

①. 方法区的垃圾收集主要回收两部分内容:常量池中废奔的常量和不再使用的类型

②. 先来说说方法区内常量池之中主要存放的两大类常量:字面量和符号引


用。 字面量比较接近Java语言层次的常量概念,如文本字符串、被声明为final


的常量值等。而符号引用则属于编译原理方面的概念,包括下面三类常量

类和接口的全限定名

字段的名称和描述符

方法的名称和描述符


③. HotSpot虚拟机对常量池的回收策略是很明确的,只要常量池中的常量没


有被任何地方引用,就可以被回收。回收废弃常量与回收Java堆中的对象非常类似。

④. 判定一个常量是否“废弃”还是相对简单,而要判定一个类型是否属于


“不再被使用的类”的条件就比较苛刻了。需要同时满足下面三个条件:

该类所有的实例都已经被回收,也就是Java堆中不存在该类及其任何派生子类的实例。


加载该类的类加载器已经被回收,这个条件除非是经过精心设计的可替换类加载器的场景,如OSGi、JSP的重加载等,否则通常是很难达成的


该类对应的java.lang.Class对象没有在任何地方被引用,无法在任何地方通过反射访问该类的方法


⑤. Java虛拟机被允许对满足上述三个条件的无用类进行回收,这里说的仅仅


是“被允许”,而并不是和对象一样,没有引用了就必然会回收。关于是否要


对类型进行回收,HotSpot虚拟机提供了一Xnoclassgc 参数进行控制,还可以


使用一verbose:class以及一XX: +TraceClass一Loading、一XX:


+TraceClassUnLoading查 看类加载和卸载信息

⑥. 在大量使用反射、动态代理、CGLib等字节码框架,动态生成JSP以及oSGi


这类频繁自定义类加载器的场景中,通常都需要Java虚拟机具备类型卸载的能


力,以保证不会对方法区造成过大的内存压力

相关文章
|
7天前
|
缓存 算法 Java
JVM实战—4.JVM垃圾回收器的原理和调优
本文详细探讨了JVM垃圾回收机制,包括新生代ParNew和老年代CMS垃圾回收器的工作原理与优化方法。内容涵盖ParNew的多线程特性、默认线程数设置及适用场景,CMS的四个阶段(初始标记、并发标记、重新标记、并发清理)及其性能分析,以及如何通过合理分配内存区域、调整参数(如-XX:SurvivorRatio、-XX:MaxTenuringThreshold等)来优化垃圾回收。此外,还结合电商大促案例,分析了系统高峰期的内存使用模型,并总结了YGC和FGC的触发条件与优化策略。最后,针对常见问题进行了汇总解答,强调了基于系统运行模型进行JVM参数调优的重要性。
JVM实战—4.JVM垃圾回收器的原理和调优
|
11天前
|
缓存 监控 算法
JVM简介—2.垃圾回收器和内存分配策略
本文介绍了Java垃圾回收机制的多个方面,包括垃圾回收概述、对象存活判断、引用类型介绍、垃圾收集算法、垃圾收集器设计、具体垃圾回收器详情、Stop The World现象、内存分配与回收策略、新生代配置演示、内存泄漏和溢出问题以及JDK提供的相关工具。
JVM简介—2.垃圾回收器和内存分配策略
|
8天前
|
消息中间件 存储 算法
JVM实战—3.JVM垃圾回收的算法和全流程
本文详细介绍了JVM内存管理与垃圾回收机制,涵盖以下内容:对象何时被垃圾回收、垃圾回收算法及其优劣、新生代和老年代的垃圾回收算法、Stop the World问题分析、核心流程梳理。
JVM实战—3.JVM垃圾回收的算法和全流程
|
4月前
|
监控 算法 Java
Java虚拟机(JVM)的垃圾回收机制深度解析####
本文深入探讨了Java虚拟机(JVM)的垃圾回收机制,旨在揭示其背后的工作原理与优化策略。我们将从垃圾回收的基本概念入手,逐步剖析标记-清除、复制算法、标记-整理等主流垃圾回收算法的原理与实现细节。通过对比不同算法的优缺点及适用场景,为开发者提供优化Java应用性能与内存管理的实践指南。 ####
|
3月前
|
监控 算法 Java
Java虚拟机(JVM)垃圾回收机制深度剖析与优化策略####
本文作为一篇技术性文章,深入探讨了Java虚拟机(JVM)中垃圾回收的工作原理,详细分析了标记-清除、复制算法、标记-压缩及分代收集等主流垃圾回收算法的特点和适用场景。通过实际案例,展示了不同GC(Garbage Collector)算法在应用中的表现差异,并针对大型应用提出了一系列优化策略,包括选择合适的GC算法、调整堆内存大小、并行与并发GC调优等,旨在帮助开发者更好地理解和优化Java应用的性能。 ####
95 0
|
1天前
|
存储 Java C++
JVM 运行时数据区
Java 虚拟机在执行 Java 程序的过程中会把它所管理的内存区域划分为若干个不同的数据区域。这 些区域都有各自的用途,以及创建和销毁的时间,有些区域随着虚拟机进程的启动而存在,有些区 域则是依赖线程的启动和结束而建立和销毁。Java 虚拟机所管理的内存被划分为如下几个区域 程序计数器(Program Counter Register):当前线程所执行的字节码的行号指示器,字节码解 析器的工作是通过改变这个计数器的值,来选取下一条需要执行的字节码指令,分支、循环、跳 转、异常处理、线程恢复等基础功能,都需要依赖这个计数器来完成; 为什么要线程计数器?因为线程是不具备记忆功能 Java 虚拟机
|
7天前
|
消息中间件 算法 Java
JVM实战—5.G1垃圾回收器的原理和调优
本文详细解析了G1垃圾回收器的工作原理及其优化方法。首先介绍了G1通过将堆内存划分为多个Region实现分代回收,有效减少停顿时间,并可通过参数设置控制GC停顿时长。接着分析了G1相较于传统GC的优势,如停顿时间可控、大对象不进入老年代等。还探讨了如何合理设置G1参数以优化性能,包括调整新生代与老年代比例、控制GC频率及避免Full GC。最后结合实际案例说明了G1在大内存场景和对延迟敏感业务中的应用价值,同时解答了关于内存碎片、Region划分对性能影响等问题。
|
3月前
|
算法 网络协议 Java
【JVM】——GC垃圾回收机制(图解通俗易懂)
GC垃圾回收,标识出垃圾(计数机制、可达性分析)内存释放机制(标记清除、复制算法、标记整理、分代回收)
|
3月前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
3月前
|
Java
JVM运行时数据区
1)虚拟机栈:每次调用方法都会在虚拟机栈中产生一个栈帧,每个栈帧中都有方法的参数、局部变量、方法出口等信息,方法执行完毕后释放栈帧 (2)本地方法栈:为native修饰的本地方法提供的空间,在HotSpot中与虚拟机合二为一
46 2