什么是運算符的結合性?
當兩個運算符的優先級一樣的時候,先算哪一個的問題,這就是結合性。
首先要明白的是:結合性對于兩個或兩個以上的優先級一樣的運算符才有意義。
比如:
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中規定計算順序的四個運算符之一,因此上面的計算順序是完全正確的。