代码
public class HelloWorld {
public static void main(String[] args) {
int i = 1;
i = i++;
int j = i++;
int k = i + ++i * i++;
System.out.println(i);
System.out.println(j);
System.out.println(k);
}
}
执行结果
4
1
11
分析
int i = 1;
将值1赋值给变量i。
i = i++;
首先i的值进入操作数栈,值为1;
然后变量i进行自增,因为自增不进入操作栈,所以是变量i变为2;
最后进行赋值操作,将操作数中的1赋值给变量i,最终i的值为1。
int j = i++;
上一步中变量i的值是1,进入操作数栈;
变量i自增,变量i的值变为2;
最后进行赋值操作,将操作数栈中的1赋值给变量j。
int k = i + ++i * i++;
首先从左往后进操作数栈;
变量i的值为2,进入操作数栈;
变量i先自增再进入操作数栈,此时进栈的值为3;
变量i先进栈,后再自增,进栈的值还是为3,变量i的值变为4;
此时,栈内数据为2,3,3;根据运算符顺序进行运算,先算乘法,3*3=9;再算加法,2+9=11;
将栈中的11赋值给k。
最后打印数据。
小结
赋值最后运算
等号右边的从左到右加载依次压入操作数栈
实际先算哪个,看运算符的优先级
自增、自减操作都是直接修改变量的值,不经过操作数栈
最后的赋值前,临时结果也是存储在操作数栈