深入java虚拟机(一) 虚拟机内存结构
java虚拟机所管理的内存区域(运行时数据区)主要分为如下几个部分:堆(heap)、方法区(method area)、虚拟机栈(VM stack)、本地方法栈(native method stack)、程序计数器(program counter register)。如图:
1、程序计数器:可以看作是当前线程所执行的字节码的行号指示器。对于多线程来说,为了线程恢复后,可以从正确的位置继续执行,每个线程都需要一个独立的程序计数器,每个计数器独立存储,所以都是线程私有的。
2、java虚拟机栈:也是线程私有的,生命周期与线程相同。每个方法在执行的同时都会创建一个栈帧(stack frame)用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每个方法从调用到执行完毕的过程,就对应着栈帧在虚拟机栈中从入栈到出栈的过程。
3、本地方法栈:与java虚拟机栈的作用相似,区别只是java虚拟机栈是为执行java方法服务的,而本地方法栈是为执行本地方法服务的。对于不同的虚拟机实现方式不同,部分虚拟机会将java虚拟机栈和本地方法栈合二为一。
4、java堆:是虚拟机最大的一块内存区域,是所有线程共享的,在虚拟机启动是创建。几乎所有的对象实例都在这里分配内存,也是java垃圾收集器管理的主要内存区域,也被称为GC堆。
5、方法区:是所有线程共享的,用于储存已经加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。某些虚拟机的实现方式,会将方法区实现为“永久代”。方法区中非常重要的一个组成部分叫做运行时常量池。