当前位置: 首页 > article >正文

【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 代码的执行过程

// 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 VMOracle最常用的 JVM,性能稳定,GC 优化丰富
J9 VMIBM / Eclipse轻量级、启动速度快,适用于云环境
Zing VMAzul低延迟、高吞吐量,适合金融行业
JRockit VMOracle(已合并到 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 下的应用代码。

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

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

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):降低垃圾回收停顿,提高吞吐量。

http://www.kler.cn/a/572855.html

相关文章:

  • 创建自定义的Spingboot启动器
  • 基于云部署DeepSeek自动分析整合Dou音爆款视频数据
  • Session ID 和 Cookie 的配合机制
  • Oracle sqlplus命令-set
  • FFMPEG利用H264+AAC合成TS文件
  • 技术提升效率 实用工具改变生活
  • 华为鸿蒙系统全景解读:从内核设计到生态落地的技术革命
  • deepseek本地集群部署调研
  • [Python入门学习记录(小甲鱼)]第0~2章:环境搭建、各种print、缩进和BIF内置函数
  • 软件测试:白盒测试详解
  • 能简述一下动态 SQL 的执行原理吗
  • 【银河麒麟高级服务器操作系统实际案例分享】数据库资源重启现象分析及处理全过程
  • 【Python】如何解决Jupyter Notebook修改外部模块后必须重启内核的问题?
  • 【音视频】FFmpeg如何查询命令帮助文档
  • 交叉编译openssl及curl
  • 设计模式详解(单例模式)
  • 4.RabbitMQ工作模型
  • EXCEL页脚如何插入表格或者图片
  • #define GBB_DEPRECATED_MSG(msg) __declspec(deprecated(msg))
  • YOLOv8 自定义目标检测