JVM之内存结构

时间:2023-03-09 19:37:54
JVM之内存结构

JVM是按照运行时数据的存储结构来划分内存结构的。JVM在运行Java程序时,将他们划分成不同格式的数据,分别存储在不同的区域,这些数据就是运行时数据。运行时数据区域包括堆,方法区,运行时常量池,程序计数器,虚拟机栈,本地方法栈。

Java堆

Java堆是JVM所管理的内存中最大的,是被所有线程共享的一块内存区域,在虚拟机启动时创建,唯一目的就是存放对象实例。所有对象实例及数组都在堆上分配内存

方法区(别名非堆)

用于存放被装载的类型信息、类型的常量池、字段信息、方法信息、类静态变量、ClassLoader的引用、Class的引用类型信息。

运行时常量池

运行时常量池是方法区的一部分,在Class文件被加载后,存放编译期生成的各种字面量和符号引用

程序计数器

程序计数器是一块较小的内存空间,可以把它看成指向待执行字节码的指针,分支,循环,跳转,异常处理,线程恢复等都需要依赖计数器。程序计数器是线程私有的。

虚拟机栈和本地方法栈

虚拟机栈是线程私有的,生命周期和线程相同,虚拟机栈描述的是Java方法执行的内存模型,每个方法在执行时都会创建一个栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。

局部变量表存放了编译期可知的各种基本数据类型、对象引用模型和returnedAddress类型(指向一条字节指令码的地址)

在JVM规范中,线程请求的栈深度大于虚拟机所允许的深度,会抛出*Error异常,虚拟机动态扩展时无法申请到足够的内存时,会抛出OutOfMemoryError异常。