由i=i++初探jvm执行原理

有题如下:

public class TestTemp {
    public static void main(String[] args) {
        int i = 1;
        i=i++;
        System.out.println(i);
    }
}

输出结果为1。对于a=b+c++,一般可以看作

  1. a=b+c;
  2. c++

按如上理解的话结果应该应该为2的,但是这里为什么结果为1呢?
首先,我们利用javap命令获取JVM字节码命令如下:

public class com.sail.TestTemp {
  public com.sail.TestTemp();
    Code:
       0: aload_0
       1: invokespecial #1                  // Method java/lang/Object."<init>":()V
       4: return

  public static void main(java.lang.String[]);
    Code:
       0: iconst_1
       1: istore_1
       2: iload_1
       3: iinc          1, 1
       6: istore_1
       7: getstatic     #2                  // Field java/lang/System.out:Ljava/io/PrintStream;
      10: iload_1
      11: invokevirtual #3                  // Method java/io/PrintStream.println:(I)V
      14: return
}

对需要关注内容添加注释如下:

//int i=1;
0: iconst_1				///常量1入栈
1: istore_1				//将栈顶int类型值保存到局部变量1中。		
//i=i++;
2: iload_1				//从局部变量1中装载int类型值入栈。
3: iinc          1, 1	//将整数值1加到指定的int类型的局部变量1中。
6: istore_1				将栈顶int类型值保存到局部变量1中。

前两步执行了int i=1;没什么好讲的。
标号2,3,6执行过程:

  1. 局部变量i入栈,i为1,栈顶为1.
  2. 局部变量i自增,此时i值为2.
  3. 加载栈顶元素到i中,i被重新赋值为1.

我们要知道JVM是基于栈的架构。

《深入分析Java Web技术内幕(修订版)》P186
JVM执行字节码指令是基于栈的架构,也就是所有的操作数必须先入栈,然后根据指令中的操作码选择从栈顶弹出若干元素进行计算后再将结果压入栈中。在JVM中操作数可以存放在每一个栈帧中的一个一个本地变量集中,即在每个方法调用时就会给这个方法分配一个本地变量集,这个本地变量集在编译时就已经确定,所以操作数入栈可以直接是常量入栈或者从本地变量集中取一个变量压入栈中。

还需要知道的一点时,一条赋值语句中,赋值操作最后执行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值