JVM主要分为下面几部分
类加载器:负责将字节码加载到 JVM 中。它根据需求动态加载类文件,并将其转换为 JVM 可执行的格式。类加载器子系统有三种常见的类加载器:启动类加载器(Bootstrap ClassLoader)、扩展类加载器(Extension ClassLoader)、应用类加载器(Application ClassLoader)。
运行时数据区:用于保存java程序运行过程中需要用到的数据和相关信息
执行引擎:字节码文件并不能直接交给底层操作系统去执行,因此需要特定的命令解析器执行引擎将字节码翻译成底层系统指令。执行引擎负责执行字节码,解释或编译字节码为机器码,他包含解释器(Interpreter)和即时编译器(JIT Compiler),其中 JIT 编译器能够将热点代码编译为机器码,以提高运行效率。
本地方法接口:会被执行引擎调用参与字节码的翻译,提供与其他编程语言(如 C/C++)交互的接口,允许 Java 程序调用本地方法。
垃圾收集器:自动管理内存,回收不再使用的对象,防止内存泄漏。垃圾收集器通常与堆区相关联,是 JVM 内存管理的重要部分。
在这里面最主要的部分是运行时数据区,它又由五部分构成,分别是:堆、方法区、栈、本地方法栈、程序计数器
堆是对象实例存储的主要区域,是 GC(垃圾收集器)管理的主要区域。
方法区可以认为是堆的一部分,用于存储已被虚拟机加载的信息,比如常量、静态变量等等
栈是程序方法运行的主要区域,栈里面存的是栈帧,栈帧里面存的是局部变量表、操作数栈、动态链接、方法出口等信息
本地方法栈与栈功能相同,区别在于本地方法栈执行的是本地方法,即一个Java调用非Java代码的接口
程序计数器主要存放的是当前线程所执行的字节码的行号,用于记录正在执行的字节码指令的地址