指令集分类
- 基于寄存器的指令集
- 基于栈的指令集 Hotspot中的Local Variable Table = JVM中的寄存器
Runtime Data Area
PC 程序计数器
存放指令位置
虚拟机的运行,类似于这样的循环:
while( not end ) {
取PC中的位置,找到对应位置的指令;
执行该指令;
PC ++;
}
JVM Stack
- Frame - 每个方法对应一个栈帧(每个栈帧对应4部分)
- Local Variable Table(局部变量表)
- Operand Stack (操作树栈)对于long的处理(store and load),多数虚拟机的实现都是原子的 jls 17.7,没必要加volatile
- Dynamic Linking (动态链接:指到运行时常量池的符号链接,检查是否解析,没解析进行动态解析,已解析直接使用)https://blog.csdn.net/qq_41813060/article/details/88379473 jvms 2.6.3
- return address a() -> b(),方法a调用了方法b, b方法的返回值放在什么地方
Heap
Method Area(方法区:逻辑概念)下面是不同版本的具体实现
- Perm Space (<1.8) 字符串常量位于PermSpace FGC不会清理 大小启动的时候指定,不能变
- Meta Space (>=1.8) 字符串常量位于堆 会触发FGC清理 不设定的话,最大就是物理内存
Runtime Constant Pool
Native Method Stack(本地方法栈)
Direct Memory(直接内存)
JVM可以直接访问的内核空间的内存 (OS 管理的内存)
NIO , 提高效率,实现zero copy
常用指令
store
load
pop
mul
sub
invoke
- InvokeStatic
- InvokeVirtual
- InvokeInterface
- InovkeSpecial 可以直接定位,不需要多态的方法 private 方法 , 构造方法
- InvokeDynamic JVM最难的指令 lambda表达式或者反射或者其他动态语言scala kotlin,或者CGLib ASM,动态产生的class,会用到的指令