什么是运算符的结合性?
当两个运算符的优先级一样的时候,先算哪一个的问题,这就是结合性。
首先要明白的是:结合性对于两个或两个以上的优先级一样的运算符才有意义。
比如:
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
由于*和++的结合性从右至左,因此*++ptr等价于*(++ptr)
在网上查询资料的时候发现:很多人问条件运算符的结合性的问题。
int i = 3;
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中规定计算顺序的四个运算符之一,因此上面的计算顺序是完全正确的。