自右向左进行运算 先算最右边的b++,先提取b的值1,然后b=b+1=2,此时b已经变为2;
然后算另一个b++,先提取b的值2,结果就是1+2+1=4
最终b的值为3 无需纠结,知道原理就行,工作中程序写成这样,不是同事会把你杀了就是项目经理会开了你!
不要抖机灵,程序不是越复杂越好,是自浅显易懂最好!!! 根据运算符的有闲心和结合性,先计算括号内的,并且从左至右。即
设 b1=b; b2 = b++; b3 = b++;
若 a = 1 + (b++) + (b++);
则 a = 1 + b1 + b2; b = b3;
举个简单的例子:
b = 1;
a = 1 + (b++) + (b++);
也就是 a = 1 + 1 + 2; b++;
结果 a = 4 , b = 3;
计算完 第一个括号内的 b 再自加,再计算二个括号内的b , 求出 a , b再自加;
为啥我算的是a=3 b=3 表达式运算时b的值一直为1; 语句结束后b才开始自增 不论有多少 假设 a = 0 , b = 0;
a = 1 + (b++) + (b++)
它都是加减 运算符顺序一致 从左到右扫
先算 1 + b然后 b++ 然后再+b 然后付给 a然后 b++
结果 a = 2 ,b = 2
我记得小甲鱼也遇到跟这道差不多的题
好像是 两个还是三个++p
但是他有提到有些编译器为了优化 把两个++p先算也就是说 两个p 都等于p + 2 达到你不想达到的结果 freejzh 发表于 2019-8-8 00:17
看了几个人的解答,感觉这个表达式的计算过程,大家好像不太统一,这说明对这个问题的理解总有人是错误的啊 ...
还有一个就是 你这个表达式在不同的编译环境下 结果可能不同 有的编译器编译没问题 结果就是 a=4,b=3;有的编译器则会报错,编译不通过,错误原因是multiple unsequenced modifications to 'b' (对变量b进行多次无序更改)
因为不同的编译器,对程序语句执行的过程是不一样的
所以还是那句话 懂自增自减运算符的规则就好,无序太过于纠结,很多时候当下没能理解的东西跳过去未免不是一件好事,因为当你更深入的学习后面的知识的时候,再返回头看之前没懂的东西,会有一种恍然大悟的感觉!!!
页:
[1]