i = i++ 和 i = ++i 的区别?
来看两段字节码吧.
(1)
int i = 1;
i = i++;
bytecode:
0: iconst_1
1: istore_1
2: iload_1
3: iinc 1,1
6: istore_1
7: return
(2)
int i = 1;
i = ++i;
bytecode:
0: iconst_1
1: istore_1
2: iinc 1,1
3: iload_1
6: istore_1
7: return
简单解释下代码的意思:
iconst_1是将1推到堆栈(内存中)
istore_1是将_1指向一个到局部变量表的索引
iload_1是将局部变量表索引0处的值推到堆栈中
iinc 1,1在局部变量表索引0处的值加1
关键就在2,3步上
(1)先执行i = i(操作是写入内存的),然后++是在局部变量表中进行的自增,程序员只能读取内存中的数据.所以结果为1;
(2)和(1)操作相反,所以结果为2;
i=i++与i=++i的区别
本文通过对比i=i++与i=++i两种表达式的字节码,解析了这两种自增运算符的不同之处及其实现原理。在第一种情况下,变量先赋值再自增,因此最终结果保持不变;而在第二种情况下,先自增后赋值,导致变量值增加。

被折叠的 条评论
为什么被折叠?



