1、基本概念
JVM是可运行Java代码的假想计算机,包括一套字节码指令集、一组寄存器、一个栈、一个垃圾回收、堆和一个存储方法域。JVM是运行与操作系统之上的,它与硬件没有直接的交互。
2、运行过程
我们都知道Java源文件,通过编译器,能够产生相应的.class文件,也就是字节码文件,而字节码文件又通过Java虚拟机中的解释器,编译成特定机器上的机器码。
①.java源文件 -> 编译器 ->字节码文件
②.字节码文件 -> JVM -> 机器码
每一种平台的解释器是不同的,但实现的虚拟机是相同的,这也就是为什么Java能够跨平台的原因。当一个程序从开始运行,这时虚拟机就开始实例化了,多个程序启动就会存在多个虚拟机实例。程序退出或关闭,则虚拟机实例消亡,多个虚拟机实例之间数据不能共享。
2.1.线程
这里所说的线程之一个程序执行过程中的一个线程实体。JVM运行一个应用并发执行多个线程。HotSpot JVM 中的 Java 线程和原生的操作系统的线程有直接的映射关系。当线程本地存储,缓冲区分配,同步对象,栈,程序计数器等准备好以后,就会创建一个操作系统原生线程。Java线程结束原生线程随之被回收。操作系统负责调度所有的线程,并把他们分配到任何可用的CPU上。当原生线程初始化完毕,就会调用Java线程的run()方法,当线程结束时,会释放原生线程和Java线程的所有资源。
Hotspot JVM 后台运行的系统线程主要有:
虚拟机线程 VM Thread | 这个线程等待JVM到达安全点操作出现。这些操作必须要在独立的线程李执行,因为当堆修改无法进行时,线程都需要JVM位于安全点。 这些操作类型有:stop-the-world 垃圾回收,线程栈 dump,线程暂停,线程偏向锁(biased Locking)解除。 |
周期性任务线程 | 这线程负责定时器事件(也就是中断),用来调度周期性操作的执行。 |
GC线程 | 这些线程支持JVM中不同的垃圾回收活动 |
编译器线程 | 这些线程在运行时动态的将字节码编译成本地平台相关的机器码 |
信号分发线程 | 这个线程接收发送到JVM的信号,并调用适当的 JVM 方法处理了 |