【笔记】JVM之PC寄存器(程序计数器)

PC寄存器(程序计数器)

1.概述

https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-2.html#jvms-2.5

image-20200706151132307

image-20200706151318577

  • 它是一块很小的内存空间,几乎可以忽略不记。也是运行速度最快的存储区域。
  • 在JVM规范中,每个线程都有它自己的程序计数器,是线程私有的,声明周期与线程的生命周期保持一致。
  • 任何时间一个线程都只有一个方法在执行,也就是所谓的当前方法。程序计数器会存储当前线程正在执行的Java方法的JVM指令地址;或者,如果是在执行native方法,则是未指定值(undefined)
  • 它是程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都需要依赖这个计数器来完成
  • 字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令
  • 它是唯一一个在Java虚拟机规范中没有规定任何OutOfMemoryError情况的区域

既没有GC也没有OOM

2.举例说明

利用java自带的javap -verbose/javap -v命令看看class文件的指令

image-20200706152510831

image-20200706153557917

PC寄存器存储指令地址

两个常见问题

1.使用PC寄存器字节码指令地址有什么用?

为什么使用PC寄存器记录当前线程的执行地址呢?

因为CPU需要不停的切换各个线程,这时候切换回来以后,就得知道接着从哪开始继续执行

JVM的字节码解释器就需要通过改变PC寄存器的值来明确下一条应该执行什么样的字节码指令

image-20200706154208973

2.PC寄存器为什么会被设定为线程私有?

image-20200706154440712

3.CPU时间片

宏观并行,微观上是通过时间片对每个程序轮流执行

image-20200706155509580

并发和并行的区别

并行VS串行

串行就像排队一样,每次执行一个任务

  • 并发: 同⼀时间段,多个任务都在执⾏ (单位时间内不⼀定同时执⾏);
  • 并⾏: 单位时间内,多个任务同时执⾏。

在GC中的概念:

  • 并⾏(Parallel) :指多条垃圾收集线程并⾏⼯作,但此时⽤户线程仍然处于等待状态。
  • 并发(Concurrent):指⽤户线程与垃圾收集线程同时执⾏(但不⼀定是并⾏,可能会交替执 ⾏),⽤户程序在继续运⾏,⽽垃圾收集器运⾏在另⼀个CPU上。