如上图三核处理器模型所示,堆内存和方法区线程共有,本地方法区、栈内存、程序计数器线程私有。
1.heap堆内存,存储实例对象,数组等资源,占用内存比例极大,内存的jvm会根据堆实际空闲比例自动调整所占内存大小,是GC的主要阵地。
2.mehod area方法区,各线程共享,存放类信息,常量,静态变量,编译后的代码等,jdk1.7及之前也称永久代,实际上永久代占用的内存空间很少,由GC负责清理,很容易导致内存溢出,即PermGen Space异常,所以在JDK1.8中,HotSpot VM取消了永久代,用元空间取而代之,元空间直接使用本地内存,理论上电脑有多少内存它就可以使用多少内存,所以不会再出现PermGen Space异常。
3.JVM Stack栈内存,当JVM在java执行方法时,会在此区域中创建一个栈帧来存放方法的各种信息,比如返回值,局部变量表和各种对象引用等,方法开始执行前就先创建栈帧入栈,执行完后就出栈。
4.Native Method Stack本地方法栈,为Native方法(加native关键字)服务,可以执行非java的语言方法。
5.PC Register程序计数器,来标识字节码文件的运行行数。