4 回答
TA贡献1815条经验 获得超6个赞
a+=b+=a+=b;
等价于
a=a+(b=b+(a=a+b));
1、运算过程中注意a是原子类型 值是拷贝的
2、a=a+(××××); //+结合率是从左到右。 即先将a压栈 然后计算括号内的,这样算就明白了,具体请看用javap -verbose 来观看字节码操作
0: iconst_2
1: istore_1 --->a
2: iconst_5
3: istore_2 --->b
4: iload_1 载入a(2)
5: iload_2 载入b(5)
6: iload_1 载入a(2)
7: iload_2 载入b(5)
8: iadd 7 (第6和7行累计 结果压栈)
9: dup 复制栈顶
10: istore_1 a(7) 把栈顶结果保存到a
11: iadd 12 (栈顶7+第5行)
12: dup 复制12
13: istore_2 b(12) 结果保存到b
14: iadd 12+2(栈顶+第4行)
15: istore_1 a(14)
TA贡献2036条经验 获得超8个赞
举个例子:int a = 2,b = 5;
int s = a+b; /赋值运算符是从右到左,也就是 s=7;
有了这个道理那么看这个就很简单了
a+=b+=a+=b;
那么简单分3段;从右到左运算
第一段:a+=b;也就是a=a+b;也就是a=7;
第二段:b+=(a+=b);已知第一段 a+=b=7;
也就是b=b+7;也就是b=5+7=12;
第三段:a+=(b+=(a+=b));已知第二段算 b=12;
那么a+=12;也就是a=a+12;也就是a=14;
TA贡献2012条经验 获得超12个赞
a+=b+=a+=b;
此表达式有三个赋值过程, 对a赋值两次, 对b赋值一次
首先是把所有的操作数都压入栈内,
先计算 最后一个a = a + b ; 计算完赋值a
然后计算 b= a + (a + b) ; 计算完赋值b, 这里需要注意的是,整个操作的值已经初始化过, 这里 a + (a + b) 前面一个a 的值不是7,应该还是2。
最后计算 a = a + (a + (a + b)) ; 计算完赋值a;
添加回答
举报