运行时数据区概述
线程共用方法区和堆空间
每个线程各自有各自的程序计数器,本地方法栈,虚拟机栈
95%的垃圾回收发生在堆空间,还有5%发生在方法区,JDK8开始方法区由永久代变为元空间,使用的是本地内存,所以发生内存溢出的问题会很少。
每个JVM只有唯一的Runtime实例,也就是运行时数据区。
三个重点:虚拟机栈,方法区,堆
线程
如果run方法可以正常执行完,或者出现异常有相应处理,那么java线程和本地线程都会回收,资源释放
如果执行run方法时出现异常未被处理,那么java线程就终止,此时本地线程决定jvm到底要不要终止。如果只剩下守护线程,那么jvm就可以终止了。
程序计数器(PC寄存器)
https://docs.oracle.com/javase/specs/jvms/se8/html/
执行引擎执行完一条指令,就去PC寄存器取下一条指令
堆和方法区存在垃圾回收,也可能OOM
栈区和本地方法栈都有OOM,
PC寄存器既没有GC,也没有OOM(内存溢出)
示例
执行引擎会从PC寄存器5的位置取操作指令istore_2,执行引擎实现数据存取,并且将字节码翻译成机器指令,进而让对应的CPU进行运算
PC寄存器就是存放指令的地址
面试问题
CPU时间片
并行并发注意区别