【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):降低垃圾回收停顿,提高吞吐量。
相关推荐
Asthenia0412几秒前
零基础指南:在Linux上用Docker和Jenkins实现Spring Cloud微服务的CI/CD
后端
byte轻骑兵3 分钟前
【C++进阶】关联容器:pair类型
开发语言·c++
Hellyc7 分钟前
SpringMVC响应数据:页面跳转与回写数据
java·前端·学习
LuckyRich115 分钟前
【boost搜索引擎】下
开发语言·c++·搜索引擎
嘵奇21 分钟前
深入解析 Spring Boot 测试核心注解
java·spring boot·后端
癞皮狗不赖皮24 分钟前
Java安全基础-反射机制
java·反射机制·java安全基础
uhakadotcom28 分钟前
BPF编程入门:使用Rust监控CPU占用
后端·面试·github
别惊鹊31 分钟前
(三)安装和使用Maven
java·maven
小样vvv37 分钟前
【面试篇】JVM
jvm·面试·职场和发展
兢兢业业的小白鼠1 小时前
Java高级JVM知识点记录,内存结构,垃圾回收,类文件结构,类加载器
java·开发语言·jvm·tomcat