1、 运行时数据区
1.1 程序计数器
当前线程所执行的字节码的行号指示器;
为了线程切换后能恢复到正确的执行位置,每个线程都需要有一个独立的程序计数器;
执行native方法,计数器值为空
说明:java虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式实现
1.2 栈
线程私有,生命周期与线程相同;
每个方法在执行时会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息;
每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程;
局部变量表存放了编译器可知的各种基本数据类型、对象引用、returnAddress类型;
进入一个方法时,这个方法在帧中分配多大的局部变量空间是完全确定的,在方法执行期间不会改变局部变量表的大小;
异常:
线程请求的栈深度大于虚拟机栈所允许的深度,就抛出StackOverflowError;
如果虚拟机栈动态扩展时无法申请到足够的内存,就抛出OutOfMemoryError。
1.3 堆
此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存;
java堆细分为:新生代 和 老年代,细分为Eden,From Servivor,To Servivor;
线程共享的Java堆中可能划分出多个线程私有的分配缓冲区(TLAB);
1.4 方法区
方法区用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等;
1.5 Note
part1: 运行时常量池
运行时常量池是方法区的一部分,用于存放编译器生成的各种字面量和符号引用