有这么一道题
输出为:
下面我再慢慢道来:
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