一,JVM内存模型
根据JVM的规范,JVM内存共分为虚拟机栈,本地方法栈,堆,方法区,程序计数器五个部分。
线程私有:
程序计数器:是当前线程所执行的字节码的行号指示器,每条线程都有一个独立的程序计数器,这类内存也称为“线程私有”的内存。正在执行Java方法的话,计数器记录的是虚拟机字节码指令的地址(当前指令的地址)。如果是Natice方法(指一个Java调用非Java代码的接口0,则是空。
虚拟机栈:每个方法在执行的时候也会创建一个栈帧,存储了局部变量,操作数,动态链接,方法返回地址。每个方法从调用到执行完毕,对应一个栈帧在虚拟机栈中的入栈和出栈。通常所说的栈,一般是指在虚拟机栈中的局部变量部分。局部变量所需内存在编译期间完成分配,如果线程请求的栈深度大于虚拟机所允许的深度,则StackOverflowError。如果虚拟机栈可以动态扩展,扩展到无法申请足够的内存,则OutOfMemoryError。
本地方法栈:和虚拟机栈类似,主要为虚拟机使用到的Native方法(指一个Java调用非Java代码的接口)服务。也会抛出StackOverflowError
线程共享:
堆:被所有线程共享的一块内存区域,在虚拟机启动的时候创建,用于存放对象实例。对可以按照可扩展实现(通过-Xmx和-Xms来控制)当队中没有内存可分配