运行时数据区
JVM运行时数据区主要包括 堆、栈、方法区、程序计数器等。其中JVM内存优化主要在线程的共享区域:***堆,方法区***中
程序计数器
程序计数器可以看做是当前执行的字节码的行号计数器,指向下一个要执行的指令代码。
如果手机java方法,记录的是虚拟机正在执行的字节码指令的地址,如果是native方法,记录的值是undifined。
程序计数器不会发生内存溢出问题
栈
本地方法栈和虚拟机栈
栈线程私有,生命周期和线程相同。
栈桢是栈的元素,每个方法在执行时会创建一个栈桢,存储局部变量表,方法出口,动态链接,操作数栈
局部变量表
栈桢中由局部变量表存储数据,存储基本数据类型的局部变量(包括方法参数)和对象的引用。局部变量表所需的内存空间在编译完成时分配。
局部变量表以变量槽(Slot)为最小单位,Slot可以复用。
操作数栈
进行算术运算或者方法传递时使用
动态链接
存放所有方法的JVM的指令地址
JAVA堆
堆被所有线程共享,主要存放被new 出来的对象以及数组。垃圾收集器根据GC算法收集堆上的对象所占的内存空间。
年轻代存储新生成对象,当年轻代满了会触发minor gc。
老年代存储长期活跃对象和大对象。老年代占满后会触发full gc
方法区
所有线程共享。存储已经被虚拟机加载的类信息(版本、方法、字段)、常量、静态变量、运行时常量池。
JDK1.8后使用元空间替代方法区,元空间使用本地内存。