JVM内存区域
运行时数据区域
运行时数据区域包括:虚拟机栈,方法区,堆,程序计数器,本地方法栈
-
线程共享
-
堆(对象实例、对象数组)
从回收内存的角度,基于分代的思想,划分:
新生代(1/3) Eden(8) survivor1(1) survivor2(1) 老年代(2/3)
-
方法区(非堆) | 元空间(
JDK8
在本地内存实现)(存储类型信息、常量、静态变量、即时编译器编译的代码缓存等数据)- 运行时常量池:编译期生成的各种字面量和字符引用
-
-
线程私有
-
程序计数器(指向当前线程正在执行的字节码的指令的地址(行号))
-
本地方法栈(当前线程运行native方法所需数据、指令、返回地址)
-
虚拟机栈
栈帧(方法): 1.局部变量表(方法中定义的变量) 2.操作数栈(值入栈出栈) 3.动态链接(动态运行时,栈帧所属方法的符号引用转化为直接引用) 4.返回地址(方法退出时,要回到最初方法被调用时的位置)
-
对象内存布局
对象在堆内存存储布局分为三块:对象头、实例数据和对齐填充(占位符)
对象头
- 自身运行时数据,包括
hashcode
、GC分代年龄
、锁状态标志、线程持有的锁、偏向线程id、偏向时间戳 - 类型指针,对象指向它的类型元数据的指针,虚拟机通过这个指针确认对象属于哪个类的实例
32位虚拟机中:对象头 = 25位对象
hashcode
+ 4位分代年龄 + 2位锁标志 + 1位固定0