JVM的运行机制
jvm(Java Virtual Machine)是用于java字节码的虚拟机,包括一套字节码指令集,一组程序寄存器,一个虚拟机栈,一个方法区和一个垃圾回收器,jvm运行在操作系统之上,不与硬件 设备直接交互
Java源文件在通过编译器之后被编译成相应的.class文件,.class文件又被jvm中的解释器编译成机器码在不同的操作系统上运行,每种系统的解释器都是不同的,但基于解释器实现的虚拟机是相同的,这也是Java跨平台的原因,在一个java进程开始运行后,虚拟机就开始实例化了,有多个进程启动就会实例化多个虚拟机实例,进程退出或者关闭,则虚拟机实例消亡,在多个虚拟机实例之间不能共享数据,
Java程序的具体运行过程
第一步Java源文件编译为字节码文件 |
第二步jvm将字节码文件编译为相应操作系统的机器码 |
第三步机器码调用相应操作系统的本地方法库执行相应的方法 |
Java虚拟机包括一个类加载器子系统(Class Loader SubSystem),运行时数据区(Runtime Data Area) 执行引擎和本地接口库。本地接口库通过调用本地方法库与操作系统交
运行时数据区分为:方法区,本地方法区,虚拟机栈(栈帧),虚拟机堆(老年代,新生代)程序计数器,
类加载器子系统
执行引擎
本地接口库
本地方法库
最底层为操作系统
其中
类加载器子系统用于将编译好.class文件加载JVM中
运行时数据区用于存储在JVM运行过程中产生的数据,包括程序计数器,方法区,本地方法区,虚拟机栈,虚拟机堆
执行引擎包括即时编译器和垃圾回收器,即时编译器用于将java字节码编译程具体的机器码,垃圾回收器用于回收运行过程中不再使用的对象
本地接口库用于调用操作系统的本地方法库完成具体的指令操作
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------借鉴于《offer来了》书籍