java中i=i++问题
public class Test {
public static void main(String[] args) {
int i = 0;
i = i ++;
System.out.println(i);
}
}
对Test.class文件进行反编译得到的结果:
从0行开始:
0)code 0 : 执行iconst_0:将int型常量压入操作数栈栈顶位置
1)code 1:执行istore_1:将操作数栈栈顶元素出栈,并将它存到一个叫局部变量表1的东西上(出栈),此时i的值为0;
2)code 2:执行iload_1:将局部变量表1的元素放到操作数栈栈顶(入栈);
3)code
3:执行iinc(递增命令):将常量值1加入到局部变量表1中;注意:这个命令没直接发生在操作数栈中,而是直接在局部变量表1中操作的。个人理解是:这个命令是个综合命令(含iadd和
istore),所以
此命令结束后,i的值为1。
6)code 6:执行istore_1:把栈顶的值存在局部变量表1中。这里奇迹出现了:要记得第三步2)操作数栈中栈顶元素为0,执行出栈操作时,栈顶元素0又把刚刚在局部变量表1中的
值
1给覆盖
为0了。
到此,所有的赋值操作都结束了。下面的操作时执行 System.out.println(i) 语句的命令
下面讨论下j = i ++的情况:
public class Test {
public static void main(String[] args) {
int i = 0;
int j = 0;
j = i ++;
System.out.println(i);
}
}
反编译得到的结果:
1)code 0 和 code 1命令:对应语句是int i = 0;此时局部变量1值为0;栈顶为空;
2)code 2 和code 3 命令:对应语句是int j = 0;此时局部变量2值为0;栈顶为空;注意:这个程序有两个局部变量1和2
3)code 4 命令iload_1:把局部变量1的值放入到操作数栈栈顶位置;
4)code 5 命令iinc:将常量值1加入到局部变量1中;
注意:这个命令没直接发生在操作数栈中,而是直接在局部变量表1中操作的。个人理解是:这个命令是个综合命令(含iadd和
istore),所以
此命令结束后,i的值为1。
5)code 8 命令istore_2:把栈顶元素存到局部变量2中;注意:此时栈顶元素值是多少啊?看3)步。
大概的情况执行java中执行 i = i++语句,虚拟机中执行命令就是这样的吧。昨晚好像没讲清楚的,
还不清楚的下次讨论++i的命令解释。。。。。记住一点:Java在执行i++时,会先找个地方把i原先的值存下来,算完++后,又把原先存下来的值覆盖到++后的值。。。。。(个人观点)
题外话:这个问题好像就Java中有的,c/c++中好像没的。