内存区域划分
线程隔离区
- 程序计数器(Program Counter Register):当前线程所执行的字节码的行号指示器
- 虚拟机栈(VM Stack):描述的是Java方法执行的内存模型,每个方法在执行的同时都会创建一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态链接、方法出口等信息;每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程;局部变量表所需的内存空间在编译期间已经确定,在方法运行期间不会改变局部变量表的大小;栈可能抛出StackOverflowError、OutOfMemoryError异常
- 本地方法栈(Native Method Stack):与虚拟机栈类似,只不过执行的方法是Native方法
线程共享区
- 堆(Heap):存放所有对象实例和数组,堆是垃圾收集器管理的主要区域,可能抛出OutOfMemoryError异常
- 方法区(Method Area):别名Non-Heap(非堆),还被称为“永生代”(Permanent Generation),用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据,可能抛出OutOfMemoryError异常
- 运行时常量池(Runtime Constant Pool):是方法区的一部分,可能抛出OutOfMemoryError异常
注意!在JDK1.7的HotSpot中,已经把原本放在方法区(永久代)的字符串常量池移出。