1. 程序计数器(Program Counter Register)
程序计数器,线程私有。是一块较小的内存空间,它可以是看作当前线程所执行的字节码的行号指示器。
2.java虚拟机栈(VM Stack)
java虚拟机栈,线程私有,会出现OOM。Java栈中存放的是一个个的栈帧,每个栈帧对应一个被调用的方法,在栈帧中包括局部变量表(Local Variables)、操作数栈(Operand Stack)、指向当前方法所属的类的运行时常量池的引用(Reference to runtime constant pool)、方法返回地址(Return Address)和一些额外的附加信息。
3.本地方法栈(Native Method Stack)
本地方法栈,线程私有,会出现OOM。与java虚拟机栈类似,为native方法服务。
4.堆(Heap)
堆,线程共享,会出现OOM。堆是jvm内存管理的最大的一块区域,此内存区域的唯一目的就是存放对象的实例,几乎所有对象实例与数组都要在堆上分配内存。它也是垃圾收集器的主要管理区域。
5.方法区(Method Area)
方法区,线程共享,会出现OOM。在方法区中,存储了每个类的信息(包括类的名称、方法信息、字段信息)、静态变量、常量以及编译器编译后的代码等。方法区是堆的一个逻辑部分,为了区分Java堆,它还有一个别名Non-Heap(非堆)。