java虚拟机内存模型

java虚拟机内存模型_第1张图片

程序计数器:

1、它是当前线程所执行的字节码的行号指示器。

2、每个线程都有自己私有的程序计数器。

3、执行java方法时,记录的是正在执行的虚拟机字节码指令的地址;

执行native方法时,计数器的值为空。

4、此内存区域是jvm中唯一一个没有规定OutOfMemoryError的区域。

 

虚拟机栈:

1、每个方法执行的时候都会创建一个栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。

2、局部变量表存储8种基本数据类型、对象引用和returnAddress类型(指向一条字节码指令的地址)。

3、局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法在栈中分配多大的局部变量空间是完全确定的,在方法运行期间不会改变局部变量表的大小。

4、long和double类型占2个局部变量空间(slot),其他类型占1个。

5、如果线程请求的栈深度大于虚拟机所允许的,抛出StackOverFlow异常。

如果可以动态扩展,但扩展时申请不到内存,抛出OutOfMemoryError。

 

本地方法栈:

1、与虚拟机栈类似,它记录虚拟机用到的native方法服务。

2、sun hotspot将本地方法栈和虚拟机栈合二为一。

 

java堆:

1、它是所有线程共享的一块内存区域,在虚拟机启动时创建。

2、它唯一的目的:存放对象实例。

3、如果在堆中没有内存再进行分配,且堆不能再进行扩展,则抛出OutOfMemoryError。

 

方法区:

1、它是各个线程共享的内存区域。

2、它用于存储已被虚拟机加载的类的信息、常量、静态变量、即时编译器编译后的代码等数据。

3、hotspot vm中这部分也被称为永久代(Permanent Generation)。

4、这个区域垃圾回收器也会进行回收,主要目标是常量池和对类型的卸载。

 

------------------------------------------------------------------------------------------------------------------------------

运行时常量池:

1、它是方法区的一部分。

2、它用来存放编译期生成的各种字面量和符号引用,以及运行时翻译出来的直接引用。

 

直接内存:

1、它并不是jvm内存区域的一部分。

2、它可以避免在java堆和native堆中来回复制数据,从而提高性能。使用时,可以使用native函数直接分配堆外内存,然后通过一个存储在java堆中的DirectByteBuffer对象作为这块直接内存的引用进行使用。

3、它不受java堆大小的限制,受本机总内存大小的限制。

 

 

 

 

你可能感兴趣的:(java虚拟机)