JVM--a == (a = b)基于栈的解释器执行过程

前言

在翻阅ConcurrentLinkedQueue的代码的时候,发现这样一段代码在JDK源码中总是出现。

 t != (t = tail) 原先总是以为这不就是 t != t ?很是纳闷,遂Demo了一下发现并不是我想象中的那样..

 

 

Demo

在运算符优先级当中寻找答案好像是找不出什么答案了,至少我没有想通..

刚好看了JVM之后一直没有用过相关的东西,这次便从字节码层面来探个究竟..

 

字节码

查看字节码内容

stack = 4,需要深度为3的操作数栈

locals = 3,需要3个Slot的局部变量空间

常量池

 

执行过程

 下面就来看一下,Java这种基于栈的解释器是怎么执行这个Demo的。

 

 

附录

虚拟机字节码指令表

https://www.jianshu.com/p/e057695f1184

转载于:https://www.cnblogs.com/microcat/p/11147945.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值