JVM内存分析系列(三)JVM内存模型初步

根据《Java虚拟机规范(第二版)》的规定,结构如下



1)程序计数器
Program Counter Register
是一小块内存空间,他的作用是当前线程所执行的行号指示器。此内存区是唯一一个没有规定OutOfMemoryError情况的区域。

2)Java虚拟机栈
Java Virtual Machine Stack
生命周期与线程相同,,描述的是java方法执行的内存模型。每个方法被执行的时候都会创建一个栈帧。

3)本地方法栈
Native Method Stack
为虚拟机使用到的native方法服务。在Sun HotSpot中,把本地方法栈和虚拟机栈和二为一了。

4)方法区
Method Area
被所有线程共享的一块内存区,存放一被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。方法区和永久代本质上并不等价,HotSpot只是用永久代实现方法区而已。

5)堆
Heap
被所有线程共享的一块内存区,存放对象实例。

6)运行时常量池
Runtime Constant Pool
是方法区的一部分,用于存放编译器生成的各种字面量和符号。例如:String类的intern()方法

7)直接内存
Direct Memory
并不是虚拟机运行时数据区的一部分,它使用了Native函数库直接分配堆外内存。

猜你喜欢

转载自phl.iteye.com/blog/1995428