彻底搞清 C/C++中a++与++a的区别

首先 a++和++a 的定义:看个例子
A:    a=5;  b=++a; // 相当于a=a+1;b=a;  结果是a=6,b=6
B:    a=5;  b=a++; // 相当于b=a;a=a+1; 结果是a=6,b=5
所以书上有:
 (1)   如果用前缀运算符对一个变量增1(减1),则在将该变量增1(减1)后,用新值在表达式中进行其他的运算。
 (2)   如果用后缀运算符对一个变量增1(减1),则用该变量的原值在表达式中进行其他的运算后,再将该变量增1(减1)后。

这里就有个问题,对于后缀运算,”用该变量的原值在表达式中进行其他的运算后“该如何理解,也就是说啥时才算表达式运算完啦。
举个列子:求a的最终值
int a=3;
a+=a+=a++*a--;
计算过程如下:
先算a++*a-- 
由于a=3 
a++等于3 //这里后缀++中的第二步自加运算还没有进行
a--等于3 //这里后缀--中的第二步自减运算还没有进行
所以 ++*a-- 等于9
a+=a++*a-- 等于a+=9等于a=a+9=3+9=12
在算a+=a 等于a=a+12=12+12=24 
然后在进行再后缀++中的第二步自加运算和后缀--中的第二步自减运算
即进行 a=a+1;此时a=25;再进行a=a-1;此时a=24 所以最终a=24

说明在一个表达中,无论有多少个等号(赋值号)都必须进行完所有的运算符后,才能进行后缀自加,自减。那么什么时候才能
算本计算单位已经结束。下面某些摘自《C语言深度剖析》
i++ 在遇到每个逗号,分号后,才认为本计算单位已经结束,i 这时候自加。
关于逗号表达式与“++”或“--”的连用,还有一个比较好的例子:
int x;
int i = 3;x = (++i, i++, i+10);
问 x的值为多少?i的值为多少?
按照上面的讲解,可以很清楚的知道,逗号表达式中,i 在遇到每个逗号后,认为本计算
单位已经结束,i 这时候自加。所以,本例子计算完后,i的值为5,x的值为 15。

关于符号的贪心法
C 语言有这样一个规则:每一个符号应该包含尽可能多的字符。也就是说,编译器将程
序分解成符号的方法是,从左到右一个一个字符地读入,如果该字符可能组成一个符号,
那么再读入下一个字符,判断已经读入的两个字符组成的字符串是否可能是一个符号的组
成部分;如果可能,继续读入下一个字符,重复上述判断,直到读入的字符组成的字符串
已不再可能组成一个有意义的符号。这个处理的策略被称为“贪心法” 。需要注意到是,除
了字符串与字符常量,符号的中间不能嵌有空白(空格、制表符、换行符等) 。比如:==是单个符号,而==是两个等号。
   按照这个规则可能很轻松的判断 a+++b表达式与 a++ +b一致。那++i+++i+++i;会被解
析成什么样子呢?希望读者好好研究研究。另外还可以考虑一下这个表达式的意思a+++++b?

分析:
++i+++i+++i   由于后缀自增,自减优先级比前缀高(ANSI/ISO C++中)编译器等效理解
为++(i++)+(i++)+i,而i++不可以作左值所以++(i++)错误,故此表达式错误
a+++++b   编译器将其理解为(a++)++ +b, 由于a++不可以作左值所以(a++)++错误,故此表达式错误 

另外特别注意 ++i在C中不是左值,在C++中才是。在C语言中像 int i=0,a=2,b=3;++i=a+b;这个表达式是非法的。
i++在C和C++中都不能作左值。