news 2026/4/15 16:06:34

JVM虚拟机(Java Virtual Machine)概览

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JVM虚拟机(Java Virtual Machine)概览

Java虚拟机(JVM)是一个可以执行Java字节码虚拟计算机

是Java平台的核心组件,实现了Java跨平台运行的特性。

一、JVM架构

JVM主要分为以下几个子系统:

  • 类加载器Class Loader:加载.class文件
  • 运行时数据区 Runtime Data Areas:包括程序计数器、JVM栈、本地方法栈、堆、方法区等。
  • 执行引擎 Execution Engine:包括解释器、即时编译器JIT、垃圾回收器GC
  • 本地方法接口JNI:用于调用本地库。
  • 本地方法库:由C/C++编写的库。

(一)类加载器Class Loader

1.类加载器分类

  • 引导类加载器 Bootstrap ClassLoader:加载核心Java类库(rt.jar)
  • 扩展类加载器 Extension ClassLoader:加载ext目录下的类
  • 应用类加载器 Application ClassLoader:加载用户类路径上的类
  • 自定义类加载器:用户自定义的类加载器

2.类加载过程

  • 加载(Loading):通过类名获取类的二进制流,将静态存储结构转化为方法区的运行时数据结构,并生成一个class对象。
  • 验证(Verification):确保类文件格式正确
  • 准备(Preparation):为静态变量分配内存并设置初始值
  • 解析(Resolution):将符号引用转为直接引用
  • 初始化(Initialization):执行类构造器<clinit>()方法,为静态变量赋实际值

3.双亲委派模型

一个类加载器在加载类时,首先委托给父类加载器,只有当父类加载器无法完成时,才自己加载。

(二)运行时数据区 Runtime Data Areas

  • 程序计数器 PC Register:线程私有,线程当前所要执行的字节码指令的地址。
  • Java虚拟机栈 JVM Stack:线程私有,存储栈帧(栈帧存储局部变量表、操作数栈、动态链接、方法出口),为Java方法服务。
  • 本地方法栈 Native Method Stack:为本地方法服务。
  • Java堆 Heap:所有线程共享,存放对象实例
  • 方法区 Method Area:所有线程共享,存储类信息、常量、静态变量
  • 运行时常量池:方法区的一部分,存放编译器生成的字面量和符号引用

1.堆的内存结构(JDK8+)

堆(Heap) ├── 新生代(Young Generation,1/3堆空间) │ ├── Eden区(8/10) │ ├── Survivor0区(1/10) │ └── Survivor1区(1/10) └── 老年代(Old Generation,2/3堆空间) 元空间(Metaspace):取代永久代,使用本地内存

2.内存区域(示例)

// 内存区域示例 public class MemoryExample { private static int staticVar = 0; // 方法区 private int instanceVar = 0; // 堆 public void method() { int localVar = 0; // 栈帧中的局部变量表 Object obj = new Object(); // 对象在堆中,引用在栈中 } }

(三)执行引擎 Execution Engine

  • 解释器(直译机):将高级编程语言一行一行直接转译运行,每次运行都要先转为另一种语言再运行(逐行解释字节码)。
  • JIT编译器(Just-in-time Compiler):在程序运行时将字节码实时编译本地机器码动态编译技术(将热点代码编译成本地机器码)。
  • 垃圾回收器(garbage Collector)自动内存管理的组件,负责回收不再使用的对象以释放堆内存。

1.垃圾回收器GC

(1)对象存活判断
  • 引用计数法
  • 可达性分析
(2)垃圾回收算法
  • 标记-清除
  • 复制算法(用于新生代)
  • 标记-整理(用于老年代)
  • 分代收集
(3)垃圾回收器:
  • Serial收集器:单线程的新代收集器,适合单核环境或小型应用程序
  • Parallel收集器:并行收集器,吞吐量优先
  • CMS收集器:并发标记清除收集器,减少停顿时间
  • G1收集器:分代收集和Region内存布局,标记整理,可预测停顿时间
  • ZGC:低延迟,通过并发标记、转译和重定位,支持TB级堆内存
  • Shenandoah:低停顿时间,并发整理

二、JVM调优

(一)常用的调优参数

  • 堆内存设置:-Xms(初始堆大小)、-Xmx(最大堆大小)
  • 新生代设置:-Xmn(新生代大小)
  • 永久代/元空间设置:
  1. -XX:PermSize、-XXMaxPerSize(Java7及之前)
  2. -XX:MetaspaceSize、-XX:MaxMetaspaceSize(Java8+)
  • 垃圾回收器选择:-XX:+UseG1GC
  • 打印GC日志:-XX:PrintGCDetails
# 堆内存设置 -Xms2g # 初始堆大小 -Xmx2g # 最大堆大小 -Xmn1g # 新生代大小 # 垃圾收集器选择 -XX:+UseG1GC # 使用G1收集器 -XX:+UseConcMarkSweepGC # 使用CMS收集器 # GC日志 -XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:gc.log # 元空间设置 -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=512m # 其他优化 -XX:+UseCompressedOops # 压缩普通对象指针 -XX:+UseStringDeduplication # 字符串去重

三、JVM监控与诊断工具

(一)命令行工具

  • jps:JVM进程状态工具
  • jstat:JVM统计信息监控
  • jmap:内存映射工具
  • jstack:线程堆栈跟踪工具
  • jinfo:配置信息工具

(二)可视化工具

  • jconsole:Java监控和管理控制台
  • VisualVM:多合一故障处理工具
  • JMC:Java任务控制
  • Arthas:阿里开源的Java诊断工具

四、版本演进

  • Java 7:引入G1收集器(实验性)
  • Java 8:永久代被元空间取代,默认使用Parallel收集器
  • Java 9:G1成为默认收集器,引入模块化系统
  • Java 11:引入ZGC,废除CMS
  • Java 17:LTS版本,性能优化和特性增强
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:00:10

Linux平台STM32CubeMX安装实战案例分享

Linux下STM32CubeMX安装实战&#xff1a;从踩坑到精通的完整指南 你有没有试过在Linux上启动STM32CubeMX&#xff0c;结果只看到一个黑窗口闪退&#xff1f;或者提示“Could not initialize GTK”却不知从何下手&#xff1f;别急&#xff0c;这几乎是每个嵌入式开发者在转向纯…

作者头像 李华
网站建设 2026/4/15 17:43:54

C++开发者必看,GCC 14如何提前实现C++26并发模型?

第一章&#xff1a;GCC 14对C26并发支持的演进背景随着C标准持续向更高版本演进&#xff0c;C26正逐步引入一系列增强并发编程能力的语言特性和库组件。GCC 14作为GNU编译器集合的重要版本&#xff0c;在支持C26早期草案特性方面扮演了关键角色&#xff0c;尤其是在并发模型、原…

作者头像 李华
网站建设 2026/4/16 11:58:22

Zephyr Flash存储驱动开发:支持片外SPI NOR实战

Zephyr驱动SPI NOR Flash实战&#xff1a;从零打通片外存储链路你有没有遇到过这样的窘境&#xff1f;手里的MCU固件越做越大&#xff0c;Web资源、AI模型、日志全塞进去后&#xff0c;原本1MB的片上Flash瞬间告急。OTA升级只能分块搬运&#xff0c;配置一改就怕写坏&#xff0…

作者头像 李华
网站建设 2026/4/15 18:39:45

learning_rate合理范围:1e-4~3e-4之间的微调经验总结

learning_rate合理范围&#xff1a;1e-4~3e-4之间的微调经验总结 在如今大模型遍地开花的时代&#xff0c;越来越多团队希望通过微调来定制专属的生成能力——无论是让Stable Diffusion学会某种艺术风格&#xff0c;还是让LLaMA理解特定领域的专业术语。但全参数微调动辄需要多…

作者头像 李华
网站建设 2026/4/16 1:39:27

GCC 14 C++26并发支持全曝光(下一代并发编程利器)

第一章&#xff1a;GCC 14 C26并发支持全貌 GCC 14 对即将发布的 C26 标准提供了初步但关键的并发编程支持&#xff0c;标志着现代 C 在多线程与异步计算模型上的进一步演进。该版本增强了对协程、原子操作、执行策略和同步机制的实现&#xff0c;使开发者能够更高效地构建可扩…

作者头像 李华