1: 类加载子系统(负责从文件系统或者网络中加载class信息,加载的类信息存放于一块成为方法区的内存空间。除了类信息外,方法区中可能还存放运行时常量池信息,包括字符串字面量和数字常量(这部分常量信息是class文件常量池部分的内存映射))
2:java栈(java方法的调用,保存着局部变量,方法参数,同时和java方法的调用、返回密切相关)
3:方法区(所有线程共享的内存区域,保存系统的类信息,比如类的字段、方法、常量池等)
4:java堆(在虚拟机启动的时候建立,它是java程序最主要的内存工作区域。几乎所有的java对象实例都存放于java堆中。堆空间是所有线程共享的,这是一块与java应用密切相关的内存区域)
5:直接内存(java的nio库允许java程序使用直接内存,参阅:NIO之直接缓冲区与非直接缓冲区。直接内存是在java堆外的、直接向系统申请的内存区间。通常,访问直接内存的速度会优于java堆。因此,出于对性能的考虑,读写频繁的场合可能会考虑使用直接内存,由于直接内存在java堆外,因此直接内存的大小不会直接受限于xmx指定的最大堆大小,但是系统内存是有限的,java堆和直接内存的总和依然受限于操作系统能给出的最大内存)
6:本地方法栈(本地方法的调用,这是java虚拟机的重要扩展,java虚拟机允许java直接调用本地方法(这个方法通常使用c编写))
7:垃圾回收系统 (对方法区、java堆和直接内存进行回收。其中java堆是垃圾回收的重点。和c/c++ 不同,java中所有的对象空间释放是隐式的,也就是说对象的释放,开发人员不需要人为干预,对于不再使用的对象,垃圾回收系统会在后台自动查找、标识并释放垃圾对象,完成对java堆,方法区和直接内存中的全自动化管理)
8:pc寄存器(每个线程的私有空间,jvm会为每个java线程创建pc寄存器)
9:执行引擎(负责执行虚拟机的字节码)