JVM运行时线程隔离区域

程序计数器

  1. 线程隔离的数据区,每条线程都需要有一个独立的程序计数器,各线程计数器互不影响,各自存储,我们称这类内存区域为-“线程私有的内存”

  2. 程序计数器是JVM内存管理的运行时数据区域较小的一块内存空间,是当前线程所执行字节码的行号指示器

    字节码解释器:可以看做是当前线程执行的字节码的行号指示器,改变这个计数器的值选取下一条要执行的字节码指令,分支,循环,跳转,异常处理,线程恢复等功能

虚拟机栈

  • 线程私有
  • 生命周期和线程一样
  • Java虚拟机栈所描述的是方法执行的内存模型

每个方法在执行时会创建一个栈帧Stack Frame,用于存储局部变量表,操作数栈,动态链接,方法出口等。 每个方法由调用到执行的过程,都对应一个栈帧从虚拟机栈中入栈到出栈的过程。

局部变量表存放了编译期间可知的各种数据类型(boolean,double,long,float,byte,short,char,int) 以及对象引用类型(reference),不等同于对象本身,可能是一个指向对象起始地址的引用指针,也可能是一个代表对象的句柄或其他与此对象相关的位置,和returnAddress类型(指向一条字节码指令的地址)

其中64位长度的long和double类型数据会占用2个局部变量空间(slot),其余的数据类型只占用1个。局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法子帧中分配多大的局部变量空间是完全确定的,在方法运行期间不会再改变局部变量表的大小

根据JVM规范,这个区域有两种异常情况:如果线程请求的栈深度大于虚拟机所允许的深度,将抛出StackOverflowError异常;如果虚拟机栈可以动态扩展(当前大部分JVM都可动态扩展,只不过JVM规范中也允许固定长度的虚拟机栈,如果扩展时没有申请到足够的内存,将会抛出OutOfMemoryError异常)

本地方法栈

Native Method Stack与虚拟机栈作用大概相同

区别在于虚拟机栈为虚拟机执行Java方法(也就是字节码服务)。
而本地方法栈服务于虚拟机的Native方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值