Java虚拟机所管理的内存包括以下几个运行时数据区: 

 

程序计数器(PCR):

1、是一块较小的内存空间,可以看做是当前线程所执行的字节码的行号指示器

2、为线程私有

3、执行Java方法有PCR,执行native方法时,PCR为空(Undefined)

4、该内存区域不会出现OME(Out Of Memory Exception)

 

Java虚拟机栈:

1、各线程私有,生命周期与线程相同

2、JVMS描述的是Java方法执行的内存模型,局部变量表,操作数栈

3、局部变量表中存储了基本类型,对象,和返回地址类型,long和double类型占两个slot

4、存在SOE(StackOverflowError)和OME

 

本地方法栈:

1、为虚拟机用到的本地方法服务

2、虚拟机规范对本地方法栈无具体规定,具体的虚拟机可以自由实现规定

3、有SOE和OME

 

Java堆:

1、内存最大的一块区域,所有线程共享,VM启动时创建,唯一目的:存放对象实例

2、也成为GC堆,是垃圾收集器管理的主要区域

3、GC堆可以处于物理上不连续的内存空间中,只要逻辑上连续即可

4、有OME

 

方法区:

1、所有线程共享,存储已被虚拟机加载的类信息,常量,静态变量,即时编译器编译后的代码等数据

2、别名非堆,是堆的一个逻辑部分

3、内存逻辑上连续即可,可以选择固定大小或可扩展,或不是想垃圾收集

4、有OME

 

运行时常量池:

1、是方法区的一部分,存放类文件,常量池信息

2、具有动态性,可以在运行期或编译期将常量放入池中

3、有OME

 

直接内存:

1、是使用native函数库直接分配的堆外内存,java堆中的DBB(DirectByteBuff)对象作为这块内存的引用

2、会受到本机内存限制

3、有OME