|
先來(lái)看一個(gè)例子:
#include <stdio.h>
int main(){
int a=10,b=1,c=2;
a=b=c;
printf( "12+3*5=%d\n", 12+3*5);
printf( "a=%d, c=%d\n", a, c);
return 0;
}
運(yùn)行結(jié)果:
12+3*5=27
a=2, c=2
1) 對(duì)于表達(dá)式12+3*5,很明顯先進(jìn)行乘法運(yùn)算,計(jì)算3*5,結(jié)果為15,再進(jìn)行加法運(yùn)算,計(jì)算12+15,結(jié)果為27。也就是說(shuō),乘法的優(yōu)先級(jí)比加法高,要先計(jì)算,這與數(shù)學(xué)中的規(guī)則是一樣的。
所謂優(yōu)先級(jí),就是當(dāng)有多個(gè)運(yùn)算符在同一個(gè)表達(dá)式中出現(xiàn)時(shí),先執(zhí)行哪個(gè)運(yùn)算符。如果不想按照默認(rèn)的規(guī)則執(zhí)行,可以加( ),例如(12+3)*5的結(jié)果為 75,(2+5)*(10-4)的結(jié)果為 42。大部分情況下,它們的規(guī)則和數(shù)學(xué)中是相同的。
2) 對(duì)于語(yǔ)句賦值語(yǔ)句a=b=c;,先執(zhí)行b=c,再執(zhí)行a=b,而不是反過(guò)來(lái),這說(shuō)明賦值操作符=具有右結(jié)合性。
所謂結(jié)合性,就是當(dāng)一個(gè)運(yùn)算符多次出現(xiàn)時(shí),先執(zhí)行哪個(gè)運(yùn)算符。先執(zhí)行右邊的叫右結(jié)合性,先執(zhí)行左邊的叫左結(jié)合性。
表達(dá)式(Expression)和語(yǔ)句(Statement)的概念在C語(yǔ)言中并沒(méi)有明確的定義:
表達(dá)式可以看做一個(gè)計(jì)算的公式,往往由數(shù)據(jù)、變量、運(yùn)算符等組成,例如3*4+5、a=c=d等,它的結(jié)果必定是一個(gè)值;
語(yǔ)句的范圍更加廣泛,不一定是計(jì)算,不一定有值,可以是某個(gè)操作、某個(gè)函數(shù)、選擇結(jié)構(gòu)、循環(huán)等。
值得注意的是:以分號(hào);結(jié)束的往往稱為語(yǔ)句,而不是表達(dá)式,例如3*4+5;、a=c=d;等。
3) 像 +、-、*、/ 這樣的運(yùn)算符,它的兩邊都有數(shù)據(jù),例如 3+4、a*3 等,有兩個(gè)操作數(shù),我們稱這樣的運(yùn)算符為雙目運(yùn)算符。后面還會(huì)講解單目運(yùn)算符和三目運(yùn)算符。
|
|