Java运行时数据区
Program Counter 程序计数器
存放指令位置
虚拟机的运行,类似于这样的循环:
while( not end ) {
取PC中的位置,找到对应位置的指令;
执行该指令;
PC ++;
}
Heap
所有虚拟机内的线程共享
Direct Memory
JVM可以直接访问的内核空间的内存 (OS 管理的内存)
NIO , 提高效率,实现zero copy
JVM Stack
- Frame - 每个方法对应一个栈帧
- Local Variable Table 局部变量表
- Operand Stack 操作数栈
对于long的处理(store and load),多数虚拟机的实现都是原子的
jls 17.7,没必要加volatile - Dynamic Linking 动态链接 (简单来说就是将链接放到一个池子里,所有的链接都去同一地方找)
https://blog.****.net/qq_41813060/article/details/88379473
jvms 2.6.3 - return address
a() -> b(),方法a调用了方法b, b方法的返回值放在什么地方
Method Area
所有线程所共享,小于1.8版本实现时Perm Space永久区,大于等于1.8实现时位Meta Space
- Perm Space (<1.8)
字符串常量位于PermSpace
FGC不会清理
大小启动的时候指定,不能变 - Meta Space (>=1.8)
字符串常量位于堆
会触发FGC清理
不设定的话,最大就是物理内存
Runtime Constant Pool
class中的常量池,在运行期存储的位置
线程共享区域
PC:program counter
VMS:VM stack 虚拟机栈
NMS:Native Method Stack
共享区域:Heap堆,Method Area