深入理解JVM之--运行时数据区域

运行时数据区域

        JVM在执行Java程序的过程中会把说管理的内粗分为不同的数据区域。有的区域是在虚拟机启动而创建,有的区域则是跟随线程的启动和结束而建立销毁。如下图,在JVM GC调优中通常都是堆、方法区。

 

1.程序计数器(Pc Register)

每个线程都有自己的Pc Register,它的作用是当前线程所执行的指令地址。

2.Java虚拟器栈(statck)

Java虚拟机栈是线程私有的,每个线程都有自己的虚拟机栈,它的生命周期与线程相同。虚拟机栈描述的是Java方法执行的内存模型:每个方法被执行时,都会创建一个栈帧,用于存储局部变量,操作数栈,动态链接,方法出口等信息。每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。后续会详细讲一下虚拟机栈中的操作数栈。

3.堆(heap)

Java堆是Jvm内存管理中内存最大的一块,堆是所有线程共享的内存区域,它用于存放所有实例对象,也是GC回收的主要对象,后续会讲到GC。

4.方法区(Method Area)

 方法区也是所有线程共享的内存区域,它主要存放被虚拟机加载的类信息,常量,静态变量等。

5.本地方法栈

与虚拟机栈类似,不过它为使用Native方法服务。

6.运行时常量池

它属于方法区中的一部分。在Class常量池中,用于存放编译期生成的字面量和符号引用,在类加载后,这部分将会存放到运行时常量池中。运行时常量池一个重要特征是具有动态性,在运行期间也可能将有新的常量放入到池中(如String类的intern()方法)。后续会讲到Class常量池,String常量池,运行时常量池的区别。