面试题:关于JVM中操作数栈和局部变量表在自增时的问题

有这么一道题

输出为:

下面我再慢慢道来:

int i = 1就不用多说了;

一句一句的解析,i = i++:

第一步 i = i++; 因为要先进行运算操作,所以i++在JVM层面来说就是首先把i  load进了操作数栈,因此操作数栈有有一个值为1,然后i++运算后局部变量表中i的值变为2;

第二步 赋值,将操作数栈的值store 进局部变量表

所以结束后i的值为1,图形解说我简单画了一下:(有点问题,最后一步赋值后操作数栈中应该就没有值了)

然后int j = i++:

第一步 依然是将iload进操作数栈,再进行i++操作,则i的本地变量表中的数据值为2

第二步 赋值,将操作数栈中的值store进j的局部变量中

则最后j的为1,画图解析:

因此还剩最后一次运算 int k = i + ++i * i++:

第一步 依然是再进行运算前将i的局部变量值load 进操作数栈中,就是2

第二步 先进行++i的运算,因为++在前所以先计算后再改变i的值所以i的局部变量变为了3,再把变量值压到操作数栈中,所以操作数栈中一共有两个值,一个2一个3

第三步 进行i++运算,再将局部变量值压到操作数栈中(此时的操作数栈一共有2,3,3),因为++在后,所以先进行*运算,则操作数中的3*3 = 9,别忘了局部变量中的i也加1变为了4

第四步 最后的加法 2 + 9 = 11 ,赋值给k,则k = 11;

这一个运算稍微有点复杂就不再画图了,直接给视频链接

https://www.bilibili.com/video/av37602130

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值