JVM(内存区域划分)-JVM 内存区域划分

时间:2024-03-08 14:42:53

JVM 是一个应用程序, 在启动的时候, 会从 操作系统 申请到一整块很大的内存区域
并且 JVM 会根据需要, 将整个内存区域, 根据功能进行划分

JVM运行时数据区(内存布局)
在这里插入图片描述

Native Method Stacks (本地方法栈) : 存储本地方法 (JVM 内部方法) 之间的调用关系

  • 线程私有

Program Counter Register (程序计数器) : 记录当前线程执行到哪个命令

  • 线程私有

JVM Stacks (虚拟机栈) : 描述 Java 方法执行的内存模型

  • 线程私有
  • 整个栈空间内部,可以任务是包含很多个元素, 每个元素表示一个方法, 每个元素称为一个 “栈帧” ,每个栈帧里会包含该方法的 入口地址,方法参数,返回地址, 形参, 局部变量 …

Heap (堆区) : 整个 JVM 空间最大的区域, 存储程序中创建的所有的对象.

  • 线程共享
  • 堆里面分为两个区域 : 新生代和老生代 ( 新生代包含三个区域: 一个Endn+ 和两个 Survivor(S0/S1) )

Metaspace (元数据区/方法区) : 存储类对象, 常量池, 静态成员

  • 线程共享
  • 一个进程只有一块, 多个线程共用

对给出的一段代码, 判断某个变量在哪个区域上?

遵循原则:

  • 局部变量在 栈
  • 普通成员变量在 堆
  • 静态成员变量在 方法区/元数据区