【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):降低垃圾回收停顿,提高吞吐量。
相关推荐
阿里嘎多学长1 天前
2026-04-30 GitHub 热点项目精选
开发语言·程序员·github·代码托管
m0_613856291 天前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
abcnull1 天前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
叶小鸡1 天前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
AI人工智能+电脑小能手1 天前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
juniperhan1 天前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
ID_180079054731 天前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
c++之路1 天前
C++23概述
java·c++·c++23
时空系1 天前
第10篇:继承扩展——面向对象编程进阶 python中文编程
开发语言·python·ai编程
专注API从业者1 天前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库