// ubuntu14.04 : y=30, z=29, x=10
// rethad5 :y=28, z=31, x=10
// windows :y=30, z=33, x=10
#include <stdio.h>
int main()
{
int x=8, y, z;
y=(++x)+(x++)+(++x);
z=(--x)+(x--)+(++x);
printf(“y=%d, z=%d, x=%d”, y, z, x);
return 0;
}
Windows:表达式y=(++x)+(x++)+(++x): C语言系统先进行两次x的自增计算,使x的值由8变为10。然后将10带入表达式中计算(即计算“x+x+x”),得结果30,并赋给变量y。最后再进行一次x的后自增计算,使变量x的值由10变为11。
Redhat5:表达式y=(++x)+(x++)+(++x): C语言系统先进行一次x的自增计算,使x的值由8变为9,然后将9带入表达式中计算(即计算“x+x”),得结果18,再进行自增,使x的值由9变为10,然后将10带入表达式中计算(即计算“18+x”),得结果30,并赋给变量y。最后再进行一次x的后自增计算,使变量x的值由10变为11。
ubuntu14.04 :表达式y=(++x)+(x++)+(++x):不区分++x和x++,一律视作先自增。