分为两部分:线程共享内存与线程独立内存两部分。线程共享包括堆内存和方法区。线程独立内存包括Java虚拟机栈、程序计数器、本地方法栈。
堆内存是虚拟机管理的最大的一块内存,也是垃圾收集器管理的主要区域。用于存放对象实例,收集器基本都采用分代收集算法,所以堆可以区分为新生代和老年代,更细致一些Eden空间,from survivor空间和To survivor 空间。
方法区在java虚拟机中描述为堆的一个逻辑部分。存储着虚拟机加载的类信息、常量和静态常量,即时编译器编译后的代码等数据。
运行时常量时方法区的一部分,class文件类的版本、字段、方法、接口、常量池。常量池用于存放编译时生成的各种字面量和符号引用。这部分信息将在类加载后进入方法区的运行常量池存放。
Java虚拟机栈描述的时java方法的内存模型,每个方法在执行的同时都会创建一个栈帧用于存储巨变变量表、操作数栈、动态链接、方法出口等。每个方法从调用至完成分过程就对应着栈帧在虚拟机入栈到出栈的过程。
程序计数器是一块较小的区域,可以看作当前线程所执行字节码的行号指示器。字节码工作时是通过改变程序计数器选择下一条需要执行的字节码指令。分支、循环、跳转、异常处理、线程恢复等基本功能都需要依赖程序计数器。
本地方法栈,虚拟机使用的native方法服务。
整理来自周志明作者的《深入理解java虚拟机》第二版的第二章,有兴趣的可以看看此书。