今天闲来无事,再次调试这个问题,发现微软的编译器还真是奇葩,经常遇到++与+=的混合计算,如下:
int a=1, b=3, c=10;
int e, f;
int d = 5;
++d += (e=++d) + c; (1)
d +=(e=d++) + c; (2)
++d +=(e=d++) + c; (3)
cout << d << “ ”<<e<< endl;
分别对上述三种进行测试得到的结果分别为(1)24 7 (2)21 5 (3)23 6
以上结果的得出的计算步骤如下:
++d += (e=++d) + c; //1.++d->d=6 2.++d->d=7 3.d=d+d=14 4.d=14+10=24
d +=(e=d++) + c; //1.d=d+d=10 2.d=10+10=20 3. d=20+1=21
++d +=(e=d++) + c; //1.d=++d=6 2. d=d+d=12 3.d=12+10=22 4.d=22+1=23
总结一下就是,如果有val++,先计算+=的表达式 ,最后再计算val=val+1;如果是++val,先计算val=val+1,然后计算+=的表达式。
如第一例:先计算++d=》d=6,然后再计算++d=》d=7,接着就计算+=表达式就是d=7+7=14,最后计算d=14+10,其实最后两步可以算做一步。
后期再测试Linux下gcc编译器的结果。。。