自增运算符 和 a+++++b 、 a++ + ++的理解

a++: 先将a的值代入表达式,在表达式运算完毕后,再将a进行++处理
++a: 先将a进行++处理,将a的值代入表达式
(注意咬字)
a+++++b在编译时会报错,(a++)+(++b)和a++ + ++b不会报错

“a+++++b”这一段根本就无法解析,编译系统从左至右扫描整条语句,先遇到a++,判断出来是一个a的后缀自加运算,然后接着扫描,遇到一个+,+是一个二目运算符,它的左边已经有一个运算数a++了,系统就向右搜索第二个运算数,又遇到一个+,++比+的运算级别要高,这时,编译系统就将两个+看成一个整体来处理,既然是++,编译系统就认定,肯定它的左边或右边有一个变量,编译系统先搜索左边,发现++,不是变量,再搜索右边,发现+b,+b是什么东西?编译系统是无法搞明白的,因此它就认为++是一个缺少左值的自增运算符,于是提示提示用户:’++’ needs l-value


另外,假如定义int a = 1,b = 2;

 c = a++ + ++b;

1:先执行b自加,b变为3;相当于:b = b+ 1;
2:求a与b之和,赋给c;相当于:c = a + b ;//c = 1+3;
3:执行第二步之后,a自加1:a++;
4:如果要输出的话,(按执行顺序)
                  b = 3;
                  c = 4;
                  a = 2;
c= a+++b;
1:先执行a+b,相当于:c= a+b = 1+2;
2:a自增,相当于:a=a+1=2;
//相当于c=a+b; a++;
//假如是 c= (a++)+b;  也是向上面的顺序一样执行。因为a++ 的意思是先将a进行++处理,再将a的值代入表达式 
//假如是 c= ++a+b;  就不一样了。先执行++a,再执行 c=a+b;
 
原文地址:https://www.cnblogs.com/simonLiang/p/6041461.html