根据《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函数库直接分配堆外内存。
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函数库直接分配堆外内存。