Java运行时数据区

Program Counter 程序计数器

存放指令位置

虚拟机的运行,类似于这样的循环:

while( not end ) {

​ 取PC中的位置,找到对应位置的指令;

​ 执行该指令;

​ PC ++;

}

Heap

所有虚拟机内的线程共享

Direct Memory

JVM可以直接访问的内核空间的内存 (OS 管理的内存)

NIO , 提高效率,实现zero copy

JVM Stack

  1. Frame - 每个方法对应一个栈帧
    1. Local Variable Table 局部变量表
    2. Operand Stack 操作数栈
      对于long的处理(store and load),多数虚拟机的实现都是原子的
      jls 17.7,没必要加volatile
    3. Dynamic Linking 动态链接 (简单来说就是将链接放到一个池子里,所有的链接都去同一地方找)
      https://blog.****.net/qq_41813060/article/details/88379473
      jvms 2.6.3
    4. return address
      a() -> b(),方法a调用了方法b, b方法的返回值放在什么地方

Method Area

所有线程所共享,小于1.8版本实现时Perm Space永久区,大于等于1.8实现时位Meta Space

  1. Perm Space (<1.8)
    字符串常量位于PermSpace
    FGC不会清理
    大小启动的时候指定,不能变
  2. Meta Space (>=1.8)
    字符串常量位于堆
    会触发FGC清理
    不设定的话,最大就是物理内存

Runtime Constant Pool

class中的常量池,在运行期存储的位置

线程共享区域

Java运行时数据区
PC:program counter
VMS:VM stack 虚拟机栈
NMS:Native Method Stack
共享区域:Heap堆,Method Area