JVM
JVM - Java虚拟机
我们编写的 Java 程序, 是不能够被 OS 直接识别的
JVM 充当翻译官的角色, 负责把我们写的的 Java 程序 ,翻译给 OS “听”, 让 OS 能够识别我们所写的 Java 代码
JVM 内存区域划分
JVM 是一个应用程序, 在启动的时候, 会从 操作系统 申请到一整块很大的内存区域
并且 JVM 会根据需要, 将整个内存区域, 根据功能进行划分
JVM运行时数据区(内存布局)
Native Method Stacks (本地方法栈) : 存储本地方法 (JVM 内部方法) 之间的调用关系
- 线程私有
Program Counter Register (程序计数器) : 记录当前正在执行指令的地址
- 线程私有
JVM Stacks (虚拟机栈) : 描述 Java 方法之间的调用关系,存储基本数据类型和对象的引用(不是对象本身, 是对象的引用,对象存储在Heap区)
- 线程私有
- 整个栈空间内部,可以任务是包含很多个元素, 每个元素表示一个方法, 每个元素称为一个 “栈帧” ,每个栈帧里会包含该方法的 入口地址,方法参数,返回地址, 形参, 局部变量 …
Heap (堆区) : 整个 JVM 空间最大的区域, 存储程序中创建的所有的对象的实例.
- 线程共享
- 堆里面分为两个区域 : 新生代和老生代 ( 新生代包含三个区域: 一个Endn+ 和两个 Survivor(S0/S1) )
Metaspace (元数据区/方法区) : 存储类对象, 常量池, 静态成员
- 线程共享
- 一个进程只有一块, 多个线程共用
对给出的一段代码, 判断某个变量在哪个区域上?
遵循原则:
- 局部变量在 栈
- 普通成员变量在 堆
- 静态成员变量在 方法区/元数据区