运行时数据区域包括:虚拟机栈,方法区,堆,程序计数器,本地方法栈
线程共享
堆(对象实例、对象数组)
从回收内存的角度,基于分代的思想,划分:
新生代(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