C語言賦值運算子考點
C語言是一種計算機程式設計語言,它既具有高階語言的特點,又具有組合語言的特點。下面,小編為大家搜尋整理了C語言賦值運算子考點,希望能給大家帶來幫助!更多精彩內容請及時關注我們應屆畢業生考試網!
簡單賦值運算子和表示式,簡單賦值運算子記為“=”。由“= ”連線的式子稱為賦值表示式。其一般形式為: 變數=表示式 例如:
x=a+b
w=sin(a)+sin(b)
y=i+++--j 賦值表示式的功能是計算表示式的值再賦予左邊的`變數。賦值運算子具有右結合性。因此
a=b=c=5
可理解為:
a=(b=(c=5))
在其它高階語言中,賦值構成了一個語句,稱為賦值語句。 而在C中,把“=”定義為運算子,從而組成賦值表示式。 凡是表示式可以出現的地方均可出現賦值表示式。例如,式子x=(a=5)+(b=8)是合法的。它的意義是把5賦予a,8賦予b,再把a,b相加,和賦予x ,故x應等於13。
在C語言中也可以組成賦值語句,按照C語言規定, 任何表示式在其未尾加上分號就構成為語句。因此如x=8;a=b=c=5;都是賦值語句,在前面各例中我們已大量使用過了。
如果賦值運算子兩邊的資料型別不相同, 系統將自動進行型別轉換,即把賦值號右邊的型別換成左邊的型別。具體規定如下:
1.實型賦予整型,捨去小數部分。前面的例2.9已經說明了這種情況。
2.整型賦予實型,數值不變,但將以浮點形式存放, 即增加小數部分(小數部分的值為0)。
3.字元型賦予整型,由於字元型為一個位元組, 而整型為二個位元組,故將字元的ASCII碼值放到整型量的低八位中,高八位為0。
4.整型賦予字元型,只把低八位賦予字元量。
void main(){
int a,b=322;
float x,y=8.88;
char c1='k',c2;
a=y;
x=b;
a=c1;
c2=b;
printf("%d,%f,%d,%c",a,x,a,c2);
}
int a,b=322;
float x,y=8.88;
char c1='k',c2;
printf("%d,%f,%d,%c",a=y,x=b,a=c1,c2=b);
本例表明了上述賦值運算中型別轉換的規則。a為整型,賦予實型量y值8?88後只取整數8.x為實型,賦予整型量b值322,後增加了小數部分。字元型量c1賦予a變為整型,整型量b賦予c2 後取其低八位成為字元型(b的低八位為01000010,即十進位制66,按ASCII碼對應於字元B)。