什么是運(yùn)算符的結(jié)合性?
當(dāng)兩個(gè)運(yùn)算符的優(yōu)先級(jí)一樣的時(shí)候,先算哪一個(gè)的問(wèn)題,這就是結(jié)合性。
首先要明白的是:結(jié)合性對(duì)于兩個(gè)或兩個(gè)以上的優(yōu)先級(jí)一樣的運(yùn)算符才有意義。
比如:
m = x + y - z;
由于算術(shù)運(yùn)算符的結(jié)合性是從左至右,因此上式等價(jià)于:
m = (x + y) - z;
再比如:
#include <stdio.h>
main()
{
int s[2] = {11, 52};
int *ptr = s;
printf("%d\n", *++ptr);
return 0;
}
答案是:52
由于*和++的結(jié)合性從右至左,因此*++ptr等價(jià)于*(++ptr)
在網(wǎng)上查詢(xún)資料的時(shí)候發(fā)現(xiàn):很多人問(wèn)條件運(yùn)算符的結(jié)合性的問(wèn)題。
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,繼續(xù)計(jì)算下一步。
k = ((i==3)?10:8);
----〉
我們知道這時(shí)候i等于4,所以,((i==3)為假。
所以k不等于10,而是等于8嘛
k = ((i==3)?10:8);
----〉
k = 8
有人問(wèn),那條件運(yùn)算符的結(jié)合性且不是從左至右了,這與書(shū)上寫(xiě)的從右至左不符?
其實(shí)上面根本牽涉不到什么結(jié)合性的問(wèn)題,只有一個(gè)運(yùn)算符會(huì)牽涉到結(jié)合性嗎。而條件運(yùn)算符是C中規(guī)定計(jì)算順序的四個(gè)運(yùn)算符之一,因此上面的計(jì)算順序是完全正確的。