【Java虚拟机】内存分配和GC机制

JAVA内存模型

【Java虚拟机】内存分配和GC机制_第1张图片

方法区:     

         存储: 被类加载的类信息,常量,静态变量,运行时常量池          

     各线程共享区域          

堆(GC):

          JVM托管的内存中最大的一块。所有线程共享,虚拟机启动时创建;唯一目的存放对象实例;所有对象实例和数组都要在对上分配;

          分代GC; 新生代和老年代:Eden,From Survior,To Survior

虚拟机栈:

          存储:局部变量表(基础数据类型+引用类型)、操作数栈,动态链接,方法出口;

          线程私有,每个方法执行时会同步创建一个栈帧,          

          每个方法从调用直到执行完成,都对应一个栈帧在虚拟机栈从入栈到出栈过程。 

          线程请求栈深度大于JVM允许的深度,StackOverflowError:    虚拟机扩展到无法申请新内存, OutOfMemoryError

本地方法栈:

        为虚拟机使用的Native方法服务

程序计数器:

对象创建过程:

  JVM遇到new命令:

  1. 检查指令参数是否可在常量池定位一个类的符号引用,检查该符号应用代表的类是否已加载,解析和初始化过;如果没有,执行类的加载;
  2. 为新生对象分配内存,从堆中分配内存。

 

你可能感兴趣的:(【Java虚拟机】内存分配和GC机制)