- 这块内存区域很小,它是当前线程所执行的字节码的行号指示器,字节码解释器通过改变这个计数器的值来选取下一条需要执行的字节码指令(就是一个指针,指向方法区中的方法字节码)
- 是用来存储指向下一条指令的地址,也即将要执行的指令代码。由执行引擎读取下一条指令。
- 是线程私有的 、不会存在内存溢出。
- 在物理上实现程序计数器是在寄存器实现的,整个cpu中最快的一个执行单元。
- 所以执行的是一个Native方法,那这个计数器是undefined(程序计数器是JVM中的概念)。
- 用来存储指向下一条指令的地址,也即将要执行的指令代码。
- 每个线程都有一个程序计数器,是线程私有的。就是一个指针,指向方法区中的方法字节码。
- 它是唯一一个在java虚拟机规范中没有OOM的区域。
- 1.因为CPU需要不停的切换各个线程,这时候切换回来以后,就得知道接着从哪开始继续执行。
- 2.JVM的字节码解释器就需要通过改变PC寄存器的值来明确下一条应该执行什么样的字节码指令。
- 为了能够准确记录各个线程正在执行的当前字节码指令地址,最好的办法自然是为每一个线程都分配一个PC寄存器。
-
1.在Hotspot JVM里的每个线程都与操作系统的本地线程直接映射。
- 解释:当一个Java线程准备好执行以后,此时一个操作系统的本地线程也同时创建一个。当Java线程执行终止后,本地线程也会被回收。
-
2.操作系统负责所有线程的安排调度到任何一个可用的CPU上。一旦本地线程初始化完毕,它就会调用Java线程中的run方法。



