【Java 基础(人话版)】Java 虚拟机(JVM)

引言

学习 Java 时,我们经常听到 "一次编译,随处运行" 这句话。这背后的核心支撑技术就是 Java 虚拟机(JVM, Java Virtual Machine)。JVM 负责运行 Java 代码,使得 Java 具有良好的跨平台能力。

但你知道吗?JVM 并不只有一种实现!我们平时使用的 HotSpot VM 只是 JVM 规范的一种实现方式,除此之外,还有 J9 VM、Zing VM、JRockit VM 等不同的 JVM。不同 JVM 各有特点,适用于不同的场景。


1. JVM 是什么?

Java 虚拟机(JVM)是运行 Java 字节码(bytecode)的虚拟机。

它的主要作用是:

  1. .class 字节码文件转换为机器码,交给底层操作系统执行。
  2. 实现 Java 语言的跨平台特性。
  3. 提供内存管理(如垃圾回收 GC)、线程管理等高级特性。

通俗一点,JVM 就像一个"翻译官",它负责把 Java 代码转换成计算机能识别的机器语言,并且让不同操作系统上的 Java 程序表现一致。


2. "一次编译,随处运行" 是怎么实现的?

Java 之所以能跨平台,是因为它采用了 "编译 - 解释" 的混合执行模式

简单来说,Java 代码的执行过程如下:

  1. 编译阶段 :Java 源代码(.java 文件)经过 Javac 编译器 ,转换成 字节码(.class 文件)
  2. 执行阶段 :JVM 读取 .class 文件,并将字节码转换为当前系统的机器码,交给 CPU 执行。

🔹 示例:Java 代码的执行过程

java 复制代码
// HelloWorld.java
public class HelloWorld {
    public static void main(String[] args) {
        System.out.println("Hello, JVM!");
    }
}

执行过程如下:

复制代码
编译:javac HelloWorld.java → 生成 HelloWorld.class
运行:java HelloWorld  →  JVM 解析字节码,执行

这一过程适用于 Windows、Mac、Linux 等不同系统,所有 JVM 只要遵循相同的 JVM 规范,都能保证相同的 Java 代码在不同平台上运行时,结果是一致的。


3. JVM 并不是只有一种!

很多人以为 JVM 只有 Oracle 提供的 HotSpot VM,其实并不是这样。

只要符合 JVM 规范,任何公司、组织甚至个人都可以实现自己的 JVM。

常见的 JVM 实现有:

JVM 实现 维护方 主要特点
HotSpot VM Oracle 最常用的 JVM,性能稳定,GC 优化丰富
J9 VM IBM / Eclipse 轻量级、启动速度快,适用于云环境
Zing VM Azul 低延迟、高吞吐量,适合金融行业
JRockit VM Oracle(已合并到 HotSpot) 曾用于服务器端高性能计算

不同 JVM 适用于不同场景,例如 HotSpot 适合通用开发,而 Zing 适合高并发、低延迟的应用。


4. JVM 的核心功能

JVM 主要包含以下几个核心部分:

① 类加载(ClassLoader)

当 Java 程序运行时,JVM 需要先把 .class 文件加载到内存。这个过程由 类加载器(ClassLoader) 负责。

类加载机制采用 "双亲委派" 模型,即:

  1. Bootstrap ClassLoader(启动类加载器) :加载 Java 核心类(如 java.lang.String)。
  2. ExtClassLoader(扩展类加载器) :加载 ext 目录中的扩展库。
  3. AppClassLoader(应用类加载器):加载 Classpath 下的应用代码。

🔹 示例:打印当前的类加载器

java 复制代码
public class ClassLoaderExample {
    public static void main(String[] args) {
        System.out.println("ClassLoader: " + ClassLoaderExample.class.getClassLoader());
    }
}

运行后会显示 sun.misc.Launcher$AppClassLoader,说明这个类是由 应用类加载器 加载的。


② 运行时数据区(JVM 内存模型)

JVM 运行时会划分出不同的内存区域,用来存储 代码、对象、方法、线程信息等

JVM 主要包含以下几个运行时内存区域:

内存区域 作用
方法区(Metaspace) 存放类信息、静态变量、常量池等
堆(Heap) 存放对象实例,垃圾回收主要发生在这里
栈(Stack) 每个线程都有自己的栈,存储局部变量、方法调用信息
程序计数器(PC) 记录当前执行的指令地址
本地方法栈(Native Stack) 处理 JNI 调用(例如调用 C 代码)

③ 垃圾回收(GC)

JVM 具备自动垃圾回收(GC)功能,负责回收 不再使用的对象,避免内存泄漏。

常见的 GC 垃圾回收器:

GC 算法 特点
Serial GC 适用于小型应用,单线程回收
Parallel GC 适用于服务器端,多线程并行回收
G1 GC 适用于大内存应用,减少 STW 停顿
ZGC 低延迟,适用于大规模高并发系统

🔹 示例:手动触发 GC

java 复制代码
public class GCExample {
    public static void main(String[] args) {
        System.gc();  // 建议 JVM 进行 GC,但不一定立即执行
        System.out.println("GC 触发");
    }
}

5. JVM 的发展趋势

现代 Java 生态系统已经不再局限于传统的 HotSpot VM,越来越多的新技术正在改进 JVM:

  1. GraalVM:支持 Java、Python、JavaScript、C 等多语言混合编程。
  2. Project Loom:引入虚拟线程(轻量级线程),提升并发能力。
  3. 新 GC(如 ZGC、Shenandoah GC):降低垃圾回收停顿,提高吞吐量。
相关推荐
全栈凯哥10 分钟前
桥接模式(Bridge Pattern)详解
java·设计模式·桥接模式
PXM的算法星球14 分钟前
【软件工程】面向对象编程(OOP)概念详解
java·python·软件工程
两点王爷14 分钟前
springboot项目文件上传到服务器本机,返回访问地址
java·服务器·spring boot·文件上传
CodeWithMe15 分钟前
【C++】线程池
开发语言·c++
小吕学编程17 分钟前
ES练习册
java·前端·elasticsearch
qsmyhsgcs29 分钟前
Java程序员转人工智能入门学习路线图(2025版)
java·人工智能·学习·机器学习·算法工程师·人工智能入门·ai算法工程师
专注API从业者39 分钟前
《Go 语言高并发爬虫开发:淘宝商品 API 实时采集与 ETL 数据处理管道》
开发语言·后端·爬虫·golang
Asthenia04121 小时前
Netty writeAndFlush与Pipeline深入分析
后端
云心似我心^o^4051 小时前
使用POI和EasyExcel使用导入
java
我是大头鸟1 小时前
SpringMVC 使用thymeleaf 进行数据展示
java·springmvc·thymeleaf