什么是运算符的结合性?
当两个运算符的优先级一样的时候,先算哪一个的问题,这就是结合性。
首先要明白的是:结合性对于两个或两个以上的优先级一样的运算符才有意义。
比如:
m
=
x
+
y
-
z;
由于算术运算符的结合性是从左至右,因此上式等价于:
m
=
(x
+
y)
-
z;
再比如:
#include
<
stdio.h
>
main()
{
int s[ 2 ] = { 11 , 52 };
int * ptr = s;
printf( " %d/n " , *++ ptr);
return 0 ;
}
答案是:52
main()
{
int s[ 2 ] = { 11 , 52 };
int * ptr = s;
printf( " %d/n " , *++ ptr);
return 0 ;
}
由于*和++的结合性从右至左,因此*++ptr等价于*(++ptr)
在网上查询资料的时候发现:很多人问条件运算符的结合性的问题。
int
i
=
3
;
int k = 0 ;
k = (i ++< 0 ) ? 9 : ((i == 3 ) ? 10 : 8 );
cout << k;
int k = 0 ;
k = (i ++< 0 ) ? 9 : ((i == 3 ) ? 10 : 8 );
cout << k;
k = (3<0)?9:((i==3)?10:8);
之后i变成4
----〉
3<0是假,所以k不为9,继续计算下一步。
k = ((i==3)?10:8);
----〉
我们知道这时候i等于4,所以,((i==3)为假。
所以k不等于10,而是等于8嘛
k = ((i==3)?10:8);
----〉
k = 8
有人问,那条件运算符的结合性且不是从左至右了,这与书上写的从右至左不符?
其实上面根本牵涉不到什么结合性的问题,只有一个运算符会牵涉到结合性吗。而条件运算符是C中规定计算顺序的四个运算符之一,因此上面的计算顺序是完全正确的。