2018-07-02 通过jvm编译指令,来解析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的操作

你可能感兴趣的:(2018-07-02 通过jvm编译指令,来解析i++与++i运算过程的区别)