3.1 前言
灰色的为单独线程私有的,红色的为多个线程共享的。
每个线程:独立包括程序计数器、栈、本地栈
线程间共享:堆、堆外内存(永久代或者元空间、代码缓存)
3.2 线程
线程是一个程序里的运行单元,JVM允许一个应用有多个线程并行的执行。
在Hotspot JVM里,每个线程都与操作系统的本地线程直接映射
- 当一个Java线程准备号执行后,此时一个操作系统的本地线程也同时创建。Java线程执行结束后,本地线程也会回收
- 操作系统负责所有线程的安排调度到任何一个可用的CPU上。一旦本地线程初始化成功,他就会调用Java线程中的run()方法
JVM系统线程
使用jconsole等调试工具,可以看到后台许多线程。这些后台线程不包括调用public static void main(String[])的main线程以及所有这个main线程自己创建的线程。
后台系统线程在Hotspot JVM中主要是:
- 虚拟机线程:需要JVM到达安全点才会出现。必须在不同的线程中发送的原因是他们都需要JVM达到安全点,这样堆才不会变化。这些线程的执行类型包括"stop-the-world"的垃圾收集,线程栈收集,线程挂起以及偏向锁撤销
- 周期任务线程:时间周期时间的体现,一般用于周期性操作的调动执行
- GC线程:对JVM里不同类型的垃圾收集行为提供了支持
- 编译线程:将字节码编译成本地代码
- 信号调度线程:接受信号并发送给JVM,在他内部通过调用适当的方法进行处理