通过JVM指令分析Java中i++与++i的区别

通过jvm编译指令,来解析为何i++与++i运算过程的区别

i++

    public void testFun(){
        int y = 13;
        int x = y++;
    }

对应指令结构

public void testFun();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=3, args_size=1
         0: bipush        13
         2: istore_1
         3: iload_1
         4: iinc          1, 1
         7: istore_2
         8: return
      LineNumberTable:
        line 7: 0
        line 8: 3
        line 9: 8

++i

    public void testFun(){
        int y = 13;
        int x = ++y;
    }
 public void testFun();              
   descriptor: ()V                   
   flags: (0x0001) ACC_PUBLIC        
   Code:                             
     stack=1, locals=3, args_size=1  
        0: bipush        13          
        2: istore_1                  
        3: iinc          1, 1        
        6: iload_1                   
        7: istore_2                  
        8: return                    
     LineNumberTable:                
       line 7: 0                     
       line 8: 3                     
       line 9: 8                     

分析

i++
         3: iload_1      //从局部变量表的slot_1位置加载变量到栈帧中
         4: iinc          1, 1 // 对slot_1位置的变量进行+1操作
         7: istore_2    // 将栈顶的值保存到slot_2,即对应代码应该是变量x
++i
         3: iinc          1, 1  // 对slot_1的变量y进行+1操作
        6: iload_1       // 从slot_1加载变量y到栈帧,此时加载的Y的值已经被+1了
        7: istore_2      // 将帧栈的值,保存到局部变量表slot_2即变量x

通过上面的操作即可明显的看到i++与++i在指令的运算顺序的区别

Note:
iinc 指令函数,对指定的int类型的变量进行+1或+2操作,如i++,i–或i+=2
根据描述可知该指令是需要指定参数的,1.指定变量,2.指定步帧
因此它的结构应该是 iinc slot_ , number ,即,对指定slot_n的变量进行+=number的操作
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值