JVM的运行机制
JVM是用于运行JAVA字节码的虚拟机,包括:
- 一套字节码指令集
- 一组程序寄存器
- 一个虚拟机栈
- 一个虚拟机堆
- 一个方法区
- 一个垃圾回收器
JVM运行在操作系统之上,不与硬件设备直接交互.
JAVA源文件通过编译器之后被编译为相应的.class
文件(字节码文件),.class
文件又被JVM中的解释器编译成机器码,在不同操作系统上运行。每种操作系统的解释器不同,但基于解释器实现的虚拟机相同,这也是java能够跨平台的原因。
java程序的具体运行过程:
- java源文件被编译器编译成字节码文件
- jvm将字节码文件编译成相应操作系统的机器码
- 机器码调用相应操作系统的本地方法库执行相应的方法。
java虚拟机包括:
- 类加载器子系统:用于将编译好的字节码文件加载到JVM中
- 运行时数据区:用于存储在JVM运行过程中产生的数据,包括:
- 程序计数器
- 方法区
- 本地方法区
- 虚拟机栈
- 虚拟机堆
- 执行引擎:包括:
- 即时编译器:用于将java字节码编译成具体的机器码
- 垃圾回收器:回收在运行过程中不再使用的对象
- 本地接口库:用于调用操作系统的本地方法库完成具体的指令操作。
多线程
在多核操作系统上,JVM允许在一个进程内同时并发执行多个线程。
JVM中的线程与操作系统中的线程是相互对应的,在JVM线程的本地存储、缓冲区分配、同步对象、栈、程序计数器等准备工作都完成时,JVM会调用操作系统的接口创建一个与之对应的原生线程;
在JVM线程运行结束时,原生线程随之被回收。
操作系统负责调度所有线程,并为其分配CPU时间片,在原生线程初始化完毕时,就会调用Java线程的run()
执行该线程;在线程结束时,会释放原生线程和Java线程所对应的资源。
在JVM后台运行的线程
- 虚拟机线程:虚拟机线程在JVM到达安全点时出现。
- 周期性任务线程:通过定时器调度线程来实现周期性操作的执行。
- GC线程:GC线程支持JVM中不同的垃圾回收活动。
- 编译器线程:编译器线程在运行时将字节码动态编译成本地平台机器码,是JVM跨平台的具体实现。
- 信号分发线程:接收发送到JVM的信号并调用JVM方法。