图说JVM内存模型

JVM内存模型图

  • 根据JVM规范,JVM内存共分为五个部分。方法区、堆、虚拟机栈、本地方法栈、程序计数器。
    在这里插入图片描述

JVM的内存结构大概分为

  • 方法区(Method Area):线程共享。存储类信息、常量、静态变量、即时编译器编译后的代码。

  • 堆(Heap):线程共享。所有的对象实例以及数组都要在堆上分配。回收器主要管理的对象。

  • 虚拟机栈(VM Stack):线程私有。存储局部变量表、操作栈、动态连接、方法出口、对象指针。
    在这里插入图片描述

  • 本地方法栈(Native Method Stack):线程私有。为虚拟机使用到 Native 方法服务。如 Java 使用 c 或者 c++ 编写的接口服务时,代码在此区运行。

  • 程序计数器(Program Counter Register):线程私有。有些文章也翻译成 PC 寄存器(PC Register),同一个东西。它可以看作是当前线程所执行的字节码的行号指示器。指向下一条要执行的指令。

方法中的变量何时开始分配空间

方法中的变量是属于局部变量,局部变量是存在虚拟机栈中,当方法被调用时,局部变量才开始分配空间,方法执行结束内存释放。

  • 静态变量在 jdk1.7(包含 jdk1.7)之前存在方法区,jdk1.8 开始存在堆中。
  • 成员变量存在堆中,在对象创建的时候分配空间。

JDK1.8 内存模型图

在这里插入图片描述

END…

猜你喜欢

转载自blog.csdn.net/Jack_Huang_888/article/details/106156424