JVM简化架构
运行时数据区
- 包括:PC寄存器、Java虚拟机栈、Java堆、方法区、运行时常量池、本地方法栈等
PC寄存器
- 每个线程拥有一个PC寄存器,是线程私有的,用来存储指向下一条指令的地址
- 在创建线程的时候,创建相应的PC寄存器
- 执行本地方法时,PC寄存器的值为undefined
- 是一块较小的内存空间,是唯一一个在JVM规范中没有规定OutOfMemoryError的内存区域
Java栈
- 栈由一系列帧(Frame) 组成(因此Java栈也叫做帧栈),是线程私有的
- 帧用来保存一个方法的局部变量、操作数栈(Java没有寄存器,所有参数传递使用操作数栈)、常量池指针、动态链接、方法返回值等
- 每一次方法调用创建一个帧,并压栈,退出方法的时候,修改栈顶指针就可以把栈针中的内容销毁
- 局部变量表存放了编译期可知的各种基本数据类型和引用类型,每个slot存放32位的数据,long、double占两个槽位
- 栈的优点:存取速度比谁快,仅次于寄存器
- 栈的缺点:存在栈中的数据大小、生存期是在编译期决定的,缺乏灵活性
Java 堆
- 用来存放应用系统创建的对象和数组,所有线程共享Java堆
- GC主要管理对空间,对分代GC来说,堆也是分代的
- 堆的优点 : 运行期动态分配内存大小,自动进行垃圾回收;
堆的缺点:效率相对较慢
方法区
- 方法区是线程共享的,通常用来保存装载的类的结构信息
- 通常和元空间关联在一起,但具体的跟JVM实现和版本有关
- JVM规范把方法区描述为堆的一个逻辑部分,但它有一个别名称为Non-heap(非堆),应是为了与Java堆区分开
运行时常量池
- 是Class文件中每个类或接口的常量池表,在运行期间的表示形式,通常包括:类的版本、字段、方法、接口等信息
- 在方法区分配
- 通常在加载类和接口到JVM后,就创建相应的运行时常量池
本地方法栈
- JVM中用来支持native方法执行的栈是本地方法栈