-----------------划重点-----------------
线程私有
1.1 程序计数器:
♦️可以看作当前线程所执行的字节码的行号指示器;
♦️为了线程切换后能恢复到正确的执行位置,每条线程都需要一个独立的程序计数器;
♦️唯一一个在java 虚拟机规范中没有规定任何OOM情况的区域;
1.2 虚拟机栈
♦️生命周期与线程相同;
♦️存放数据:基本数据类型、对象的引用;
♦️异常: 线程请求的栈深度大于虚拟机所允许的深度报stackOverflowError
栈可以动态扩展,扩展时无法申请到足够的内存,抛OOM;
1.3 本地方法栈
♦️与虚拟机栈的区别:虚拟机栈为java方法服务,本地方法栈为native 方法服务;
♦️异常:和虚拟机栈一样一样的;
线程共享的
1.4 java堆(红色五角星)
♦️jvm中内存最大,所有线程共享,该内存对象的唯一目的就是存放对象实例;
♦️是gc管理的主要区域,根据gc分代回收算法分为新生代和老生代,这个重点留到gc部分吧……
♦️java堆可以处于物理上不连续的内存空间,只要逻辑上是连续的即可。实现时,可以是固定大小,也可以是可扩展的。扩展通过 -Xmx 和 -Xms 控制;
♦️当实例申请不到内存空间时 抛OOM;
1.5 方法区
♦️用于存储已被加载的类信息,常量,静态变量,即时编译器编译后的代码;
♦️可以选择不实现垃圾收集;
♦️运行时常量池:Class文件中的常量池信息。存放编译期生成的字面量和符号引用(菜狗表示这是什么鬼 - -),发生在类加载之后;
♦️ 申请不到内存抛OOM;
-----------菜狗必背下图-------------