7.虚拟机栈-操作数栈

操作数栈 Operand Stack

  1. 每一个独立的栈帧除了包含局部变量表之外,还包含一个FIFO的操作数栈,也成为表达式栈Expression Stack
  2. 操作数栈,在方法执行过程中,根据字节码指令,往栈中写入数据或提取数据,即Push Pop
    • 某一些字节码指令将值压入操作数栈,某些字节码指令取出值,使用他们之后再压入
    • 比如 复制 交换 求和等操作
  3. 操作数栈,主要用于保存计算过程中的中间结果,同时计算过程中的变量临时存储空间
  4. 操作数栈是JVM执行引擎的一个工作区,当一个方法刚开始执行的时候,一个新的栈帧也会被创建,这个方法的操作数栈是空的
    1. 这次操作数栈是有长度的,一旦确定之后不可改变
  5. 每一个操作数栈都会拥有一个明确的栈深度,用于存储数据,其所需的最大深度在编译期就定义好了,保存在方法Code属性中 为maxStack的值 使用javap -v 中的stack=%d 这个值就是操作数栈的最大深度
  6. 栈中元素可以是任意的java数据类型
    • 32bit类型占一个深度 8种基本数据类型 引用数据类型
    • 64bit类型占两个深度 long double
  7. 操作数栈并非采用访问索引的方法进行数据访问,而是通过标准的入栈和出栈操作完成
  8. 如果调用的方法带有返回值,其返回值会加入当前栈帧中的操作数栈,并更新PC寄存器下一条需要执行的字节码指令
  9. 操作数栈中的元素数据类型必须与字节码指令的序列严格匹配,这由编译器在编译时期进行验证,同时在类加载过程中的类验证阶段的数据流分析阶段再次验证
  10. JVM解释引擎是基于栈的执行引擎,其中栈指的是操作数栈
  11. 栈顶缓存技术 Top Of Stack Cashing
    1. 基于栈的虚拟机锁使用的零地址指令更加紧凑,但完成一项操作的时候必然需要更多的入栈出栈指令,这同时也就意味着将需要更多的指令分派(instruction dispatch)次数和内存读写次数
    2. 由于操作数是存储内存中,因此频繁执行内存读写操作必然会影响执行速度.为了解决这个问题,HotSpot JVM提出了栈顶缓存 Top-of-Stack Cashing 技术,将栈顶元素全部缓存在物理CPU的寄存器中,以此降低对内存的读写次数,提高执行引擎的执行效率
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值