一:运行时数据区
1.这当中线程 共享和线程私有:
01.线程共享:
堆, 方法区
02.线程私有
虚拟机栈,本地方法栈,程序计数器
程序计数器:
在计算机操作系统中程序计数器表示这个程序要执行的下一个指令的地址,对于JVM中的程序计数器可以看做是当前线程所执行的字节码的行号指示器,每个线程都有一个程序计数器(当线程都在执行的时候,如果线程要切换将要保证线程回归到正确的位置),重要的一点——程序计数器,这是JVM规范中唯一一个没有规定会导致OutOfMemory(内存泄露,下文简称OOM)的区域。
虚拟机栈:
基本数据类型的变量和对象的引用变量都存在此区域;
遵循“先进后出,后进先出”的原则;
这块区域可能会抛出StackOverflowError或者OOM错误。设置JVM参数”-Xss228k”(栈大小为228k)。
StackOverflowError:
线程请求的栈深度大于了虚拟机规定的最大深度;
OutOfMemoryError:
虚拟机在扩展栈时,无法申请到足够的内存空间,
本地方法栈:
在Hotspot中虚拟机栈和本地方法栈合为一体,
堆:
所有对象的实力和数组开辟的空间都在此区域保存;
所有线程共享;
GC主要回收对象的区域;
堆分区:
新生代
老年代
永久代
方法区:(静态区)
所有线程共享;
方法(包含构造函数),接口 定义在此区域;
所有方法的信息;
存放静态变量+常量