package 面试题;
/**
* @BelongsProject: untitled
* @BelongsPackage: 面试题
* @Author: mcc
* @CreateTime: 2021-02-17 07:40
* @Description:自增变量
*/
public class Test1 {
public static void main(String[] args) {
int i = 1;//①
i = i++;//②
int j = i++;//③
int k = i + ++i * i++;//④
System.out.println("i=" + i);
System.out.println("j=" + j);
System.out.println("k=" + k);
}
}
①定义局部变量i
②i自增,然后赋值
- ++在i的后面,所以先将i的值压入操作数栈
- i变量自增1,自增的位置在局部变量表
- 等号右边算完后进行赋值操作,把操作数栈中的值赋值给i,可见局部变量表中的2被覆盖掉
③i自增然后赋值给j
- ++在i的后面,所以先将i的值压入操作数栈
- i变量自增1,自增的位置在局部变量表
- 等号右边算完后进行赋值操作,把操作数栈中i的值赋值给j,此时i的值为2,j为1
④混合操作,压入操作数栈的顺序是从左到右的
- 把i的值压入操作数栈
- ++在i前,i变量自增1,然后再将i的值压入操作数栈
- ++在i后,先把i的值压入操作数栈,然后i变量自增1
- 把操作数栈中前两个弹出求乘积结果再压入栈
- 把操作数栈中的值弹出求和,再赋值给k
总结
- 赋值=,最后计算
- =右边的从左到右加载,依次压入操作数栈
- 实际先算哪个,看运算符优先级
- 自增、自减操作都是直接修改变量的值,不经过操作数栈
- 最后的赋值之前,临时结果也是存储在操作数栈中