剑指JVM:虚拟机实践与性能调优
上QQ阅读APP看书,第一时间看更新

2.2 线程

线程是一个程序里的运行单元。JVM允许一个应用有多个线程并行执行。在HotSpot虚拟机中,每个线程都与操作系统的本地线程直接映射。当一个Java线程准备好执行以后,此时这个操作系统的本地线程也会同时创建。Java线程执行终止后,本地线程也会回收。

操作系统负责将线程调度到任何一个可用的中央处理器(Central Processing Unit,CPU)上。一旦本地线程初始化成功,它就会调用Java线程中的run()方法。run()方法正常执行完成包含两种情况。一种是执行过程中未出现异常,方法正常执行结束。另一种是执行过程中出现了异常但是触发了相应的异常处理机制。方法正常执行完成之后,Java线程和本地线程都会被回收,并释放相应的资源。

需要强调的一点,如果执行run()方法的过程中出现了一些未捕获的异常或者有些异常没有及时处理,这时就会导致Java线程终止,本地线程再决定JVM是否要终止。JVM是否要终止取决于当前线程是不是最后一个非守护线程,非守护线程也称为用户线程,用户线程可以认为是系统的工作线程,它会完成这个程序要完成的业务操作,当一个Java应用内只有守护线程时,JVM自动退出。

守护线程是一种特殊的线程,就和它的名字一样,它是系统的守护者,在后台默默完成一些系统性的服务。在HotSpot虚拟机中,常见的守护线程主要包括以下3种。

(1)垃圾回收线程:这种线程对在JVM里不同种类的垃圾收集行为提供了支持。

(2)编译线程:这种线程在运行时会将字节码编译成本地代码。

(3)手动创建守护线程:在调用start()方法前调用setDaemon(true)可以将线程标记为守护线程。