JVM只识别字节码,不依赖Java语言本身。它通过统一的类文件格式、运行时数据区、加载验证机制及内存模型,支持Kotlin、Scala等任意生成合规.class文件的语言共存与互操作,高级特性由编译器翻译为字节码实现。
Java虚拟机(JVM)本身不“懂”Java语言,它只认字节码(Bytecode)。只要一门语言能编译成符合JVM规范的字节码,就能在JVM上运行——这是多语言共存的根本原因。
JVM的设计目标是语言中立。它定义了一套严格、稳定的指令集(如iconst_1、aload_0、invokevirtual)、类文件格式(Class File Format)、运行时数据区(堆、方法区、栈等)和加载验证机制。任何语言只要生成的.class文件满足这些约束,JVM就一视同仁地加载、验证、解释或编译执行。
例如:
所有JVM语言共享同一套类加载机制(双亲委派)、相同的内存布局(如对象在堆中存储,方法信息在元空间)、一致的线程模型和异常处理语义。这意味着:
JVM不提供高阶函数、模式匹配、尾递归优化或不可变集合等高级特性——这些全部由各语言的编译器在编译期“翻译”为等效的字节码。比如:
多语言共存不仅靠字节码兼容,更依赖成熟配套:
本质上,JVM是“字节码操作系统”,语言只是它的应用层。只要编译器忠实产出合规字节码,多语言共存就不复杂但容易忽略细节。