package com.aozhi.cailinyan;
public class IpulsPuls {
public static void main(String[] args) {
//i++ 先把i压入操作数栈 在自增。
//++i 把++i计算出来压入操作数栈。
int i = 1;
i = i++; //i压入操作数栈【1】,i++ 为2 ,完之后操作数栈又赋值给i 所以i=1(曾经等于2又被操作数栈给覆盖回1了)
int j = i++;//i压入操作数栈【1】,i++ i为2,完之后操作数栈又赋值给j 所以j=1 i=2
int k = i + ++i * i++;//i压入操作数栈【2】,++i压入操作数栈【3】i压入操作数栈【3】 (此时i++ i=4)相乘得9 ;操作数栈最终结果【2+9=11】,完之后又赋值给k=11,i=4。
System.out.println(i);
System.out.println(j);
System.out.println(k);
System.out.println(i);
}
}
打印结果:
4
1
11
4
总结:
- 赋值=,最后计算
- =右边从左到右加载值依次操作数栈
- 实际先算哪个,看优先级运算符
- 自增。自减的操作都是直接修改变量的值,不经过操作数栈
- 最后在赋值之前,临时结果也是存储在操作数栈里
建议观看:《JVM虚拟机规范》关于指令的部分