我们所编写的程序代码被编译成字节码文件 执行JRE(java运行环境) 实际上是JVM分析字节码解释的代码 并且执行
所以知道JVM的架构 可以让我们更有效的编写代码
JVM是什么:
JVM是一个虚拟机是一种软件实现的物理机器。java开发的概念WORA(一次编写到处运行),运行一个虚拟机。
编译器将.java文件编译成.class文件 输入到JVM加载和执行类文件。
JVM架构图
JVM是如何工作的呢? 如上述架构图所示,JVM分为三个主要的子系统:
1 类装入器子系统
2 运行时数据区
3 执行引擎
1 类装入器子系统 Java的动态类加载功能是由类装入器子系统。 它装载的链接。 并初始化类文件时,它是 指一个类第一次运行时,而不是编译时间。
1.1装货
将由该组件加载类。 模拟线路类装入器、扩展类加载器和应用程序类加载器是三个类加 载器将帮助实现它。 辅助程序类加载器——负责引导类路径加载类,除了rt.jar。高优先级将装载机。
扩展类加载器——负责装入类内部ext文件夹(jre lib)。
应用程序类加载器负责加载应用程序级别的类路径提到,路径环境变量等。
上面的类加载器将遵循代表团层次算法而加载的类文件。
1.2连接 验证——字节码校验器会检查生成的字节码是否正确如果验证失败我们会验证错误。
准备——对于所有静态变量的内存分配和分配默认值。
解决——所有象征性的内存引用替换为最初的引用从方法区。
1.3初始化 这是类装入的后阶段,这里所有的人静态变量 与原来的值将被指派,静态块将被执行。
2 运行时数据区 运行时数据区域分为5个主要组件:
1 方法区——所有的类级别的数据将存储在这里,包括静态变量。 每个JVM区域只有一个方 法,它是一个共享资源。
2 堆区域——所有的对象和相应的实例变量和数组将存储在这里。 还有一堆区域每个 JVM。 自方法和堆区域多个线程共享内存,存储的数据不是线程安全的。
3 堆栈区域——每一个线程,一个单独的运行时堆栈将被创建。 对于每一个方法调用,一个 条目将称为栈内存堆栈帧。 所有局部变量将被创建在栈内存中。 堆栈区域是线程安全 的,因为它不是一个共享资源。 堆栈帧分为三个实体:
(1)局部变量数组——有多少相关的方法局部变量以及相应的值将被存储在这里。
(2)操作数栈——如果任何中间操作要求执行,操作数栈作为运行时工作区执行操作。
(3)帧数据——所有的符号对应的方法存储在这里。 在任何的情况下异常catch块信息将保存 在帧数据。
4 电脑注册——每个线程必须分开PC寄存器,的地址当前执行的指令一旦指令执行PC寄存 器更新下一个指令。
5 本地方法栈——本地方法栈保存本机方法的信息。 为每一个线程,将创建一个单独的本地 方法栈。
3 执行引擎 被分配到的字节码运行时数据区将执行的执行引擎。 字节码的执行引擎读取并执行这一 块一块的。 翻译——解释器解释字节码的速度,但执行缓慢。 解释器的缺点是,当一个方法被调用多 次,每次都需要一个新的解释。
JIT编译器——JIT编译器中和解释器的缺点。 执行引擎将使用翻译的帮助转换字节码,但 是当它发现重复的代码它使用JIT编译器,编译整个字节码和改变本机代码。 这将使用本 机代码直接重复方法调用,从而改善系统的性能。
中间代码生成器——生成中间代码
代码优化器——负责优化生成中间代码
目标代码生成器——负责生成机器代码或本机代码
分析器(一个特殊的组件)——负责寻找热点,即是否多次调用的方法。
垃圾收集器——收集并删除未引用的对象。 垃圾收集可以通过调用触发“system . gc()”,但 执行是没有保证的。 JVM的垃圾收集收集创建的对象。
Java Native Interface(JNI)——JNI将互动本机方法库并提供所需的本地库执行引擎。
本机方法库——这是一个收集的本地库所需的执行引擎。