JVM运行内存模型

JVM运行内存模型图:

注意下图中的线程共享问题。
JVM运行内存模型

JVM运行内存分为5个部分:

  • 1.虚拟机栈(VM Stack):是类加载器加载的类文件(字节码)的方法执行的内存模型:
    JVM运行内存模型
    当一个方法执行时虚拟机栈会产生一个“栈帧”,在栈帧中保存方法信息。方法的执行-结束过程就是“栈帧”在虚拟机栈中的一个入-出栈过程。

  • 2.本地方法栈:基本类似于虚拟机栈,但是针对的对象是虚拟机本地的方法。

  • 3.:保存对象实例,几乎所有的对象实例是在堆上分配。
    JVM运行内存模型

在堆内存里面分为新生代和老生代俩个内存区域;对象在新生代中分配内存。而老生代中存储的是一些存活久的对象。堆内存是GC的主要区域,GC会在下章介绍。

  • 4.方法区:又称为永久代,存储已经被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等。

  • 5.程序计数器:当前线程执行的字节码行号指示器,也就相当于一个计数器,它显示了现在执行的代码行。字节码解释器通过程序计数器可以选取到下一条需要被执行的字节码执行。像循环、异常处理、分支、线程恢复等需要有清楚执行流程的基础功能都要依赖程序计数器。

  • 直接内存:在程序运行过程中可能需要直接内存的参与。