JVM虚拟机(Java Virtual Machine)概览
2026/5/7 23:50:05 网站建设 项目流程

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版本,性能优化和特性增强

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询