JVM的简化架构和运行时数据区

JVM的简化架构和运行时数据区

Java内存分配

JVM的简化架构

理解栈、堆、方法区之间的交互关系

class文件装载到虚拟机过后,装载进来的二进制文件流存放在内存区域的方法区

运行时数据区

包括:PC寄存器、Java虚拟机栈、Java堆、方法区、运行时常量池、本地方法栈等

❤:PC(Program Counter)寄存器说明:

  1. 每个线程拥有一个PC寄存器,是线程私有的,用来存储指向下一条指令的地址
  2. 在创建线程的时候,创建相应的PC寄存器
  3. 执行本地方法时,PC寄存器的值是undefined
  4. 是一块较小的内存空间,是唯一一个在JVM规范中没有规定OutOfMemoryError的内存区域

Java栈

栈由一系列帧(Frame)组成(因此Java栈也叫作栈帧),是线程私有的。

帧用来保存一个方法的局部变量、操作数栈(Java没有寄存器,所有参数传递使用操作数栈)、常量池指针、动态链接、方法返回值等

每一次方法调用创建一个帧,并压栈,退出方法的时候,修改栈顶指针就可以把栈帧中的内容销毁

❤:局部变量表存放了编译期可知的各种基本数据类型和应用类型,每个slot存放32位的数据,long、double占两个槽位

栈的优点:存取速度比堆快、仅次于寄存器

栈的缺点:存在栈中的数据大小、生存期是在编译器决定的,缺乏灵活性

Java堆

❤:用来存放应用系统创建的对象和数组,所有线程共享Java堆

❤:GC主要就是管理堆空间,对分代GC来说,堆也是分代的

堆的优点:运行期动态分配内存大小,自动进行垃圾回收

堆的缺点:效率相对较慢

方法区

方法区是线程共享的,通常用来保存装载的类的结构信息

(运行时的常量池、字段、方法的字节码、类初始化)

通常和元空间关联在一起,但具体的跟JVM实现和版本有关

JVM规范把方法区描述为堆的一个逻辑部分,但它有一个别名称为Non-heap(非堆),应是为了与Java堆区分开

运行时常量池

是Class文件中每个类或接口的常量池表,在运行期间的表示形式,通常包括:类的版本、字段、方法、接口等信息

❤:在方法区分配

❤:通常在加载类和接口到JVM后,就创建相应的运行时常量池

本地方法栈:

在JVM中用来支持native方法执行的栈就是本地方法栈

栈、堆、方法区交互关系

理解并掌握JVM的简化架构

理解栈、堆、方法区之间的交互关系

---- The end of this article ----