int i=0;i=i++
package algorithms.com.guan.javajicu;
public class Inc {
public static void main(String[] args) {
Inc inc = new Inc();
int i = 234;
inc.fermin(i);
i= i ++;
System.out.println(i);
}
void fermin(int i){
i++;
}
}
运行结果是234
分析如下
看看字节码就明白了
源代码:
1 public class test{
2 public static void main(String[] args){
3 int i = 234;
4 i = i++;
5 System.out.println(i);
6 }
7 }
|
编译之后的字节码:
public static void main(java.lang.String[]);
0: sipush 234
3: istore_1
4: iload_1
5: iinc 1, 1
8: istore_1
9: getstatic #2; //Field java/lang/System.out:Ljava/io/PrintStream;
12: iload_1
13: invokevirtual #3; //Method java/io/PrintStream.println:(I)V
16: return
|
我们分析一下字节码
0: sipush 234 //将常量234压入操作数栈
3: istore_1 //将操作数栈中的数值存到局部变量区1号位置上
4: iload_1 //将局部变量区1号位置上的值压入操作数栈
5: iinc 1, 1 //将局部变量区1号位置上的数值增1
8: istore_1 //将操作数栈中的数值存到局部变量区1号位置上
|
现在很明显了:它先把i压入栈,然后把i(在原来的位置上)加1,然后又把栈上的旧值写回i。这就导致了i被原来的旧值给覆盖了,所以值没有变化。
posted on 2018-04-13 19:27 lijingran 阅读(1328) 评论(0) 编辑 收藏 举报