Java虚拟机管理的内存分为以下几个区域
1. 程序计数器(Program Counter Register):
一块较小的内存,主要看作当前线程所执行的字节码的行号指示器。每个线程都有一个独立的程序计数器。当线程执行的java方法,计数器记录的字节码的行号;当线程执行的native方法,计数器值则为空。(此区域为java虚拟机中唯一一个没有规定任何OutOfMemoryError的区域)
2. Java虚拟机栈(java Virtual Machine Stacks)
线程私有,主要描述java方法执行的内存模型:每个方法执行时都会创建一个栈帧,存储局部变量表,操作数栈,方法出口等信息。其中我们常说的栈内存,其实就是局部变量表。
3. 本地方法栈(Native Method Stacks)
主要为虚拟机用到的native方法服务。
4. Java堆
Java堆是被所有线程共享的一块内存区域,用于存放对象实例,堆可分为新生代和老年代。其实垃圾回收器管理的主要区域,该区可以物理上不连续,逻辑上连续即可(-Xmx,-Xms设置)。其中java堆还可细分为新生代和老生代,其中新生代又可分为Eden空间,FromSurvivor空间和Tosurvivor空间(和垃圾回收机制有关)
5. 方法区
方法区也是所有线程共享的内存区域,存储虚拟机已经加载的类信息,静态变量,常量,即时编译器编译的代码等信息。被称作永久区,因为垃圾回收在此区域很少,垃圾回收在该区域主要针对常量池的回收和类卸载。运行时常量池也是方法区的一部分。
PS:其中堆和方法区是多线程共享的,其它三个区则是线程隔离的。