通过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_<n> , number ,即,对指定slot_n的变量进行+=number的操作