1.内存结构
所有线程共享的数据区:堆、方法区
线程私有的数据区:程序计数器、虚拟机栈、本地方法栈
2.运行时数据区域
2.1 程序计数器
- 记录程序的执行位置
- 线程执行java方法,程序计数器记录正在执行的虚拟机字节码指令的地址;执行本地方法,程序计数器为空
- 没有规定内存溢出(OutofMemoryError)情况的区域
2.2 虚拟机栈
- 描述java方法执行的内存模型
- 每个方法执行的同时都会创建一个栈帧
- 栈帧中存储局部变量表、操作数栈、动态链接、方法出口;局部变量表中存放基本数据类型、对象应用、returnAddress
- 此区域抛出两种异常:
(1) 线程请求的栈深度大于虚拟机所允许的最大深度抛出堆栈溢出错区(StackOverflowError)
(2)虚拟机在扩展时无法申请过到足够的内存空间,内存溢出(OutofMemoryError)
2.3 本地方法栈
为虚拟机使用的Native方法服务
2.4 堆
- 内存中最大的一块
- 存放对象实例
- 垃圾收集器管理的主要区域,又被称为GC堆
- 可以处于物理上不连续的内存空间,逻辑上连续即可
2.5 方法区
- 存储已被虚拟机加载的类信息、常量、静态变量等
- 可不实现垃圾收集,又称为“永久代”
- 回收目标主要针对常量池的回收和类型的卸载
2.5.1 运行常量池
- 存放编译期生成的字面量(用于表示固定值的符号)和符号引用
- 相比于Class文件常量池具备动态性,运行期间也可将