JVM 运行时数据区
1 JAVA虚拟机栈(栈区)
2 本地方法栈
3 JAVA堆(堆区)
4 方法区
5 程序计数区
一 JAVA堆
堆内存(HEAP) 也是垃圾收集管理器的主要区域 也称GC堆
用于存放JAVA对象实例
JVM中占用内存最大的区域 所有线程共享
抛出OutOfMemory异常 即内存不够无法再new新对象
注:从内存回收的角度 分为:新生代 老年代
从内存分配的角度 相当于多个线程私有的分配缓冲区
二 JAVA虚拟机栈
即 栈内存 是Stack Java方法执行的内存模型
储存java方法执行时的局部变量(以栈帧的形式,包括数据类型,对象的引用,方法执行结束后释放)
线程私有 生命周期与线程相同
抛出OOM StackOverFlow异常
每个java方法执行都会创建一个栈帧 一个java方法从北调用到执行完成 =一个栈帧再虚拟机中从入栈到出栈
局部变量表所需内存空间再方法变一时就会完成分配 再方法运行时不会改变大小
三 本地方法栈
与java虚拟机栈类似 但是执行Native方法服务
四 方法区
堆的一个逻辑不浮粉 为了与java堆区分 也被称为 非堆区域
储存已被虚拟机加载的类信息 常量 静态变量等数据
线程共享
该区域的内存回收主要是针对运行时常量池和对类的卸载 又称 永久代 回收条件苛刻 很少出现垃圾收集
包括一个运行时常量池
是方法区的一部分 存放类文件再编译时生成的各种字面量&符号引用
动态性 运行时也可增加新的常量 比如 String intern()
五 程序计数器
当前线程所执行的字节码的行号指示器
实现异常处理 线程恢复等基础功能
通过改变计数器的值 来选取吓一跳执行的字节码指令
线程私有 内存空间小
为了是线程切换后恢复到正确的执行位置 每条线程都配有一个独立的程序计数器 各线程互不影响 独立存储的 内存区域