久久精品水蜜桃av综合天堂,久久精品丝袜高跟鞋,精品国产肉丝袜久久,国产一区二区三区色噜噜,黑人video粗暴亚裔

C語言教程/第二章:數(shù)據(jù)類型、運算符、表達(dá)式2

來自站長百科
跳轉(zhuǎn)至: 導(dǎo)航、? 搜索

實型量[ ]

實型常量[ ]

實型也稱為浮點型。實型常量也稱為實數(shù)或者浮點數(shù)。在C語言中,實數(shù)只采用十進(jìn)制。它有二種形式: 十進(jìn)制數(shù)形式指數(shù)形式

  1. 十進(jìn)制數(shù)形式 由數(shù)碼0~ 9和小數(shù)點組成。例如:0.0,.25,5.789,0.13,5.0,300.,-267.8230等均為合法的實數(shù)。
  2. 指數(shù)形式 由十進(jìn)制數(shù),加階碼標(biāo)志“e”或“E”以及階碼(只能為整數(shù),可以帶符號)組成。其一般形式為a E n (a為十進(jìn)制數(shù),n為十進(jìn)制整數(shù))其值為 a*10,n 如: 2.1E5 (等于2.1*10,5), 3.7E-2 (等于3.7*10,)-2*) 0.5E7 (等于0.5*10,7), -2.8E-2 (等于-2.8*10,)-2*)以下不是合法的實數(shù) 345 (無小數(shù)點) E7 (階碼標(biāo)志E之前無數(shù)字)  -5 (無階碼標(biāo)志) 53.-E3 (負(fù)號位置不對) 2.7E (無階碼)

標(biāo)準(zhǔn)C允許浮點數(shù)使用后綴。后綴為“f”或“F”即表示該數(shù)為浮點數(shù)。如356f和356.是等價的。例2.2說明了這種情況:

void main()
{
 printf("%f\n%f\n",356.,356f);
}

void 指明main不返回任何值 利用printf顯示結(jié)果 結(jié)束

實型變量[ ]

  • 實型變量分為兩類:單精度型和雙精度型,
  • 其類型說明符為float 單精度說明符,double 雙精度說明符。在Turbo C中單精度型占4個字節(jié)(32位)內(nèi)存空間,其數(shù)值范圍為3.4E-38~3.4E+38,只能提供七位有效數(shù)字。雙精*度型占8 個字節(jié)(64位)內(nèi)存空間,其數(shù)值范圍為1.7E-308~1.7E+308,可提供16位有效數(shù)字。
  • 實型變量說明的格式和書寫規(guī)則與整型相同。
  • 例如: float x,y; (x,y為單精度實型量)

double a,b,c; (a,b,c為雙精度實型量)

  • 實型常數(shù)不分單、雙精度,都按雙精度double型處理。
void main()
{
  float a;
  double b;
  a=33333.33333;
  b=33333.33333333333333;
  printf("%f\n%f\n",a,b);
}

此程序說明float、double的不同

a ■■■■

b ■■■■■■■■

a<---33333.33333

b<---33333.33333333333;;

顯示程序結(jié)果

此程序說明float、double的不同

float a;

double b;

a=33333.33333;

b=33333.33333333333333;

從本例可以看出,由于a 是單精度浮點型,有效位數(shù)只有七位。而整數(shù)已占五位,故小數(shù)二位后之后均為無效數(shù)字。b 是雙精度型,有效位為十六位。但Turbo C 規(guī)定小數(shù)后最多保留六位,其余部分四舍五入。

[Practice] //floatint a=32;
float b;
double d;
b=12345678;
d=b*100;
d=d+a;
d=d+58.123456;'Vtable
a,2,32
b,4,0.0
d,8,0.0
of Vtable
'Vupdate
1,32
2,0
3,0
2,12345678.00000
3,1234567800
3,1234567832
3,1234567890.123456
of Vupdate
of Practice
[Practice] //1int a=543;
float b;
b=123.123962+a;
b=b-100;
a=b;'Vtable
a,2,543
b,4,0.0
of Vtable
'Vupdate
1,543
2,0.0
2,123.123962
2,23.123962
1,23
of Vupdate
of Practice
<pre>

==字符型量==
字符型量包括字符常量和字符變量。

===字符常量===
字符常量是用單引號括起來的一個字符。例如'a','b','=','+','?'都是合法字符常量。在C語言中,字符常量有以下特點: 
#字符常量只能用單引號括起來,不能用雙引號或其它括號。
#字符常量只能是單個字符,不能是字符串。
#字符可以是字符集中任意字符。但數(shù)字被定義為字符型之后就

不能參與數(shù)值運算。如'5'和5 是不同的。'5'是字符常量,不能參與運算。

===轉(zhuǎn)義字符===
轉(zhuǎn)義字符是一種特殊的字符常量。轉(zhuǎn)義字符以反斜線"\"開頭,后跟一個或幾個字符。轉(zhuǎn)義字符具有特定的含義,不同于字符原有的意義,故稱“轉(zhuǎn)義”字符。例如,在前面各例題printf函數(shù)的格式串中用到的“\n”就是一個轉(zhuǎn)義字符,其意義是“回車換行”。轉(zhuǎn)義字符主要用來表示那些用一般字符不便于表示的控制[[代碼]]。

常用的轉(zhuǎn)義字符及其含義

*轉(zhuǎn)義字符  轉(zhuǎn)義字符的意義
*\n      回車換行
*\t      橫向跳到下一制表位置
*\v      豎向跳格
*\b      退格
*\r      回車
*\f      走紙換頁
*\\      反斜線符"\"
*\'      單引號符
*\a      鳴鈴
*\ddd     1~3位八進(jìn)制數(shù)所代表的字符
*\xhh     1~2位十六進(jìn)制數(shù)所代表的字符

廣義地講,C語言字符集中的任何一個字符均可用轉(zhuǎn)義字符來表示。表2.2中的\ddd和\xhh正是為此而提出的。ddd和hh分別為八進(jìn)制和十六進(jìn)制的ASCII代碼。如\101表示字?quot;A" ,\102表示字母"B",\134表示反斜線,\XOA表示換行等。轉(zhuǎn)義字符的使用
<pre>
void main()
{
int a,b,c;
a=5; b=6; c=7;
printf("%d\n\t%d %d\n %d %d\t\b%d\n",a,b,c,a,b,c);
}

程序練習(xí)轉(zhuǎn)義字符的使用

a、b、c為整數(shù) 5->a,6->b,7->c

調(diào)用printf顯示程序運行結(jié)果

printf("%d\n\t%d %d\n %d %d\t\b%d\n",a,b,c,a,b,c);

程序在第一列輸出a值5之后就是“\n”,故回車換行;接著又是“\t”,于是跳到下一制表位置(設(shè)制表位置間隔為8),再輸出b值6;空二格再輸出c 值7后又是"\n",因此再回車換行;再空二格之后又輸出a值5;再空三格又輸出b的值6;再次后"\t"跳到下一制表位置(與上一行的6 對齊),但下一轉(zhuǎn)義字符“\b”又使退回一格,故緊挨著6再輸出c值7。

字符變量[ ]

字符變量的取值是字符常量,即單個字符。字符變量的類型說明符是char。字符變量類型說明的格式和書寫規(guī)則都與整型變量相同。

例如:

char a,b; 每個字符變量被分配一個字節(jié)的內(nèi)存空間,因此只能存放一個字符。字符值是以ASCII碼的形式存放在變量的內(nèi)存單元之中的。如x的十進(jìn)制ASCII碼是120,y的十進(jìn)制ASCII碼是121。對字符變量a,b賦予'x'和'y'值: a='x';b='y';實際上是在a,b兩個單元內(nèi)存放120和121的二進(jìn)制代碼: a 0 1 1 1 1 0 0 0 b 0 1 1 1 1 0 0 1

所以也可以把它們看成是整型量。 C語言允許對整型變量賦以字符值,也允許對字符變量賦以整型值。在輸出時, 允許把字符變量按整型量輸出,也允許把整型量按字符量輸出。 整型量為二字節(jié)量,字符量為單字節(jié)量,當(dāng)整型量按字符型量處理時, 只有低八位字節(jié)參與處理。

main()
{
  char a,b;
  a=120;
  b=121;
  printf("%c,%c\n%d,%d\n",a,b,a,b);
} 
a ■ b ■
a <-- 120
b <--- 121

顯示程序結(jié)果

本程序中說明a,b為字符型,但在賦值語句中賦以整型值。從結(jié)果看,a,b值的輸出形式取決于printf函數(shù)格式串中的格式符,當(dāng)格式符為"c"時,對應(yīng)輸出的變量值為字符,當(dāng)格式符為"d"時,對應(yīng)輸出的變量值為整數(shù)。

void main()
{
  char a,b;
  a='x';
  b='y';
  a=a-32;
  b=b-32;
  printf("%c,%c\n%d,%d\n",a,b,a,b);
}

a,b被說明為字符變量并賦予字符值

把小寫字母換成大寫字母

以整型和字符型輸出

本例中,a,b被說明為字符變量并賦予字符值,C語言允許字符變量參與數(shù)值運算,即用字符的ASCII 碼參與運算。由于大小寫字母的ASCII 碼相差32,因此運算后把小寫字母換成大寫字母。然后分別以整型和字符型輸出。

[Practice] //charint a=49;
char b;
char d;
b=a+10;
d=a+b;'Vtable
a,2,49
b,1,隨機
d,1,隨機
of Vtable
'Vupdate
1,49
2,隨機
3,隨機
2,';'
3,'l'
of Vupdate
of Practice
[Practice] //char c1,c2;
c1='a';c2='b';
c1=c1-32;c2=c2-32;'Vtable
c1,1,隨機
c2,1,隨機
of Vtable
'Vupdate
1,隨機;2,隨機
1,'a';2,'b'
1,'A';2,'B'
of Vupdate
of Practice

字符串常量[ ]

字符串常量是由一對雙引號括起的字符序列。例如: "CHINA" ,"C program:" , "$12.5" 等都是合法的字符串常量。字符串常量和字符常量是不同的量。它們之間主要有以下區(qū)別:

  1. 字符常量由單引號括起來,字符串常量由雙引號括起來。
  2. 字符常量只能是單個字符,字符串常量則可以含一個或多個字符。
  3. 可以把一個字符常量賦予一個字符變量,但不能把一個字符串常量賦予一個字符變量。在C語言中沒有相應(yīng)的字符串變量。這是與BASIC 語言不同的。但是可以用一個字符數(shù)組來存放一個字符串常量。在數(shù)組一章內(nèi)予以介紹。
  4. 字符常量占一個字節(jié)的內(nèi)存空間。字符串常量占的內(nèi)存字節(jié)數(shù)等于字符串中字節(jié)數(shù)加1。增加的一個字節(jié)中存放字符"\0"(ASCII碼為0)。這是字符串結(jié)束的標(biāo)志。例如,字符串 "C program"在內(nèi)存中所占的字節(jié)為:C program\0。字符常量'a'和字符串常量"a"雖然都只有一個字符,但在內(nèi)存中的情況是不同的。
  • 'a'在內(nèi)存中占一個字節(jié),可表示為:a
  • "a"在內(nèi)存中占二個字節(jié),可表示為:a\0符號常量

符號常量[ ]

在C語言中,可以用一個標(biāo)識符來表示一個常量,稱之為符號常量。符號常量在使用之前必須先定義,其一般形式為:

  1. define 標(biāo)識符 常量

其中#define也是一條預(yù)處理命令(預(yù)處理命令都?quot;#"開頭),稱為宏定義命令(在第九章預(yù)處理程序中將進(jìn)一步介紹),其功能是把該標(biāo)識符定義為其后的常量值。一經(jīng)定義,以后在程序中所有出現(xiàn)該標(biāo)識符的地方均代之以該常量值。習(xí)慣上符號常量的標(biāo)識符用大寫字母,變量標(biāo)識符用小寫字母,以示區(qū)別。

#define PI 3.14159
void main()
{
  float s,r;
  r=5;
  s=PI*r*r;
  printf("s=%f\n",s);
}

由宏定義命令定義PI 為3.14159 s,r定義為實數(shù) 5->r PI*r*r->s

顯示程序結(jié)果 float s,r; r=5; s=PI*r*r; 本程序在主函數(shù)之前由宏定義命令定義PI 為3.14159,在程序中即以該值代替PI 。s=PI*r*r等效于s=3.14159*r*r。應(yīng)該注意的是,符號常量不是變量,它所代表的值在整個作用域內(nèi)不能再改變。也就是說,在程序中,不能再用賦值語句對它重新賦值。


變量的初值和類型轉(zhuǎn)換[ ]

變量賦初值[ ]

在程序中常常需要對變量賦初值,以便使用變量。語言程序中可有多種方法,在定義時賦以初值的方法,這種方法稱為初始化。在變量說明中賦初值的一般形式為: 類型說明符 變量1= 值1,變量2= 值2,……; 例如:

int a=b=c=5;
float x=3.2,y=3f,z=0.75;
char ch1='K',ch2='P';

應(yīng)注意,在說明中不允許連續(xù)賦值,如a=b=c=5是不合法的。

void main()
{
  int a=3,b,c=5;
  b=a+c;
  printf("a=%d,b=%d,c=%d\n",a,b,c);
}
a<---3,b<--0,c<---5
b<--a+c

顯示程序運行結(jié)果

變量類型的轉(zhuǎn)換[ ]

變量的數(shù)據(jù)類型是可以轉(zhuǎn)換的。轉(zhuǎn)換的方法有兩種, 一種是自動轉(zhuǎn)換,一種是強制轉(zhuǎn)換。

自動轉(zhuǎn)換[ ]

自動轉(zhuǎn)換發(fā)生在不同數(shù)據(jù)類型的量混合運算時,由編譯系統(tǒng)自動完成。自動轉(zhuǎn)換遵循以下規(guī)則:

  1. 若參與運算量的類型不同,則先轉(zhuǎn)換成同一類型,然后進(jìn)行運算。
  2. 轉(zhuǎn)換按數(shù)據(jù)長度增加的方向進(jìn)行,以保證精度不降低。如int型和long型運算時,先把int量轉(zhuǎn)成long型后再進(jìn)行運算。
  3. 所有的浮點運算都是以雙精度進(jìn)行的,即使僅含float單精度量運算的表達(dá)式,也要先轉(zhuǎn)換成double型,再作運算。
  4. char型和short型參與運算時,必須先轉(zhuǎn)換成int型。
  5. 在賦值運算中,賦值號兩邊量的數(shù)據(jù)類型不同時, 賦值號右邊量的類型將轉(zhuǎn)換為左邊量的類型。 如果右邊量的數(shù)據(jù)類型長度左邊長時,將丟失一部分?jǐn)?shù)據(jù),這樣會降低精度, 丟失的部分按四舍五入向前舍入。圖21表示了類型自動轉(zhuǎn)換的規(guī)則。
void main()
{
  float PI=3.14159;
  int s,r=5;
  s=r*r*PI;
  printf("s=%d\n",s);
}
PI<--3.14159
s<--0,r<--5
s<--r*r*PI
顯示程序運行結(jié)果
float PI=3.14159;
int s,r=5;
s=r*r*PI; 

本例程序中,PI為實型;s,r為整型。在執(zhí)行s=r*r*PI語句時,r和PI都轉(zhuǎn)換成double型計算,結(jié)果也為double型。但由于s為整型,故賦值結(jié)果仍為整型,舍去了小數(shù)部分。

強制類型轉(zhuǎn)換[ ]

強制類型轉(zhuǎn)換是通過類型轉(zhuǎn)換運算來實現(xiàn)的。其一般形式為: (類型說明符) (表達(dá)式) 其功能是把表達(dá)式的運算結(jié)果強制轉(zhuǎn)換成類型說明符所表示的類型。例如: (float) a 把a轉(zhuǎn)換為實型(int)(x+y) 把x+y的結(jié)果轉(zhuǎn)換為整型在使用強制轉(zhuǎn)換時應(yīng)注意以下問題:

  1. 類型說明符和表達(dá)式都必須加括號(單個變量可以不加括號),如把(int)(x+y)寫成(int)x+y則成了把x轉(zhuǎn)換成int型之后再與y相加了。
  2. 無論是強制轉(zhuǎn)換或是自動轉(zhuǎn)換,都只是為了本次運算的需要而對變量的數(shù)據(jù)長度進(jìn)行的臨時性轉(zhuǎn)換,而不改變數(shù)據(jù)說明時對該變量定義的類型。
main()
{
  float f=5.75;
  printf("(int)f=%d,f=%f\n",(int)f,f);
} 
f<--5.75

將float f強制轉(zhuǎn)換成int f float f=5.75;printf("(int)f=%d,f=%f\n",(int)f,f); 本例表明,f雖強制轉(zhuǎn)為int型,但只在運算中起作用, 是臨時的,而f本身的類型并不改變。因此,(int)f的值為 5(刪去了小數(shù))而f的值仍為5.75。

基本運算符和表達(dá)式[ ]

運算符的種類、優(yōu)先級和結(jié)合性[ ]

C語言中運算符和表達(dá)式數(shù)量之多, 在高級語言中是少見的。正是豐富的運算符和表達(dá)式使C語言功能十分完善。 這也是C語言的主要特點之一。

C語言的運算符不僅具有不同的優(yōu)先級, 而且還有一個特點,就是它的結(jié)合性。在表達(dá)式中, 各運算量參與運算的先后順序不僅要遵守運算符優(yōu)先級別的規(guī)定,還要受運算符結(jié)合性的制約, 以便確定是自左向右進(jìn)行運算還是自右向左進(jìn)行運算。 這種結(jié)合性是其它高級語言的運算符所沒有的,因此也增加了C語言的復(fù)雜性。

運算符的種類C語言的運算符可分為以下幾類:

  1. 算術(shù)運算符 用于各類數(shù)值運算。包括加(+)、減(-)、乘(*)、除(/)、求余(或稱模運算,%)、自增(++)、自減(--)共七種。
  2. 關(guān)系運算符 用于比較運算。包括大于(>)、小于(<)、等于(==)、 大于等于(>=)、小于等于(<=)和不等于(!=)六種。
  3. 邏輯運算符 用于邏輯運算。包括與(&&)、或(||)、非(!)三種。
  4. 位操作運算符 參與運算的量,按二進(jìn)制位進(jìn)行運算。包括位與(&)、位或(|)、位非(~)、位異或(^)、左移(<<)、右移(>>)六種。
  5. 賦值運算符 用于賦值運算,分為簡單賦值(=)、復(fù)合算術(shù)賦值(+=,-=,*=,/=,%=)和復(fù)合位運算賦值(&=,|=,^=,>>=,<<=)三類共十一種。
  6. 條件運算符 這是一個三目運算符,用于條件求值(?:)。
  7. 逗號運算符 用于把若干表達(dá)式組合成一個表達(dá)式(,)。
  8. 指針運算符 用于取內(nèi)容(*)和取地址(&)二種運算。
  9. 求字節(jié)數(shù)運算符 用于計算數(shù)據(jù)類型所占的字節(jié)數(shù)(sizeof)。
  10. 特殊運算符 有括號(),下標(biāo)[],成員(→,.)等幾種。

優(yōu)先級和結(jié)合性[ ]

C語言中,運算符的運算優(yōu)先級共分為15級。1級最高,15級最低。在表達(dá)式中,優(yōu)先級較高的先于優(yōu)先級較低的進(jìn)行運算。 而在一個運算量兩側(cè)的運算符優(yōu)先級相同時, 則按運算符的結(jié)合性所規(guī)定的結(jié)合方向處理。 C語言中各運算符的結(jié)合性分為兩種,即左結(jié)合性(自左至右)和右結(jié)合性(自右至左)。例如算術(shù)運算符的結(jié)合性是自左至右,即先左后右。如有表達(dá)式x-y+z則y應(yīng)先與“-”號結(jié)合, 執(zhí)行x-y運算,然后再執(zhí)行+z的運算。這種自左至右的結(jié)合方向就稱為“左結(jié)合性”。而自右至左的結(jié)合方向稱為“右結(jié)合性”。 最典型的右結(jié)合性運算符是賦值運算符。如x=y=z,由于“=”的右結(jié)合性,應(yīng)先執(zhí)行y=z再執(zhí)行x=(y=z)運算。 C語言運算符中有不少為右結(jié)合性,應(yīng)注意區(qū)別,以避免理解錯誤。

算術(shù)運算符和算術(shù)表達(dá)式基本的算術(shù)運算符

  1. 加法運算符“+”加法運算符為雙目運算符,即應(yīng)有兩個量參與加法運算。如a+b,4+8等。具有右結(jié)合性。
  2. 減法運算符“-”減法運算符為雙目運算符。但“-”也可作負(fù)值運算符,此時為單目運算,如-x,-5等具有左結(jié)合性。
  3. 乘法運算符“*”雙目運算,具有左結(jié)合性。
  4. 除法運算符“/”雙目運算具有左結(jié)合性。參與運算量均為整型時, 結(jié)果也為整型,舍去小數(shù)。如果運算量中有一個是實型,則結(jié)果為雙精度實型。
void main(){
printf("\n\n%d,%d\n",20/7,-20/7);
printf("%f,%f\n",20.0/7,-20.0/7);
}

雙目運算具有左結(jié)合性。參與運算量均為整型時, 結(jié)果也為整型,舍去小數(shù)。如果運算量中有一個是實型,則結(jié)果為雙精度實型。 printf("\n\n%d,%d\n",20/7,-20/7);

printf("%f,%f\n",20.0/7,-20.0/7);

本例中,20/7,-20/7的結(jié)果均為整型,小數(shù)全部舍去。而20.0/7和-20.0/7由于有實數(shù)參與運算,因此結(jié)果也為實型。

求余運算符(模運算符)“%”雙目運算,具有左結(jié)合性。要求參與運算的量均為整型。 求余運算的結(jié)果等于兩數(shù)相除后的余數(shù)。

void main(){
printf("%d\n",100%3);
}

雙目運算,具有左結(jié)合性。求余運算符% 要求參與運算的量均為整型。本例輸出100除以3所得的余數(shù)1。

自增1,自減1運算符[ ]

自增1運算符記為“++”,其功能是使變量的值自增1。自減1運算符記為“--”,其功能是使變量值自減1。自增1,自減1運算符均為單目運算,都具有右結(jié)合性??捎幸韵聨追N形式: ++i i自增1后再參與其它運算。--i i自減1后再參與其它運算。

i++  i參與運算后,i的值再自增1。

i--  i參與運算后,i的值再自減1。

在理解和使用上容易出錯的是i++和i--。 特別是當(dāng)它們出在較復(fù)雜的表達(dá)式或語句中時,常常難于弄清,因此應(yīng)仔細(xì)分析。

void main(){
int i=8;
printf("%d\n",++i);
printf("%d\n",--i);
printf("%d\n",i++);
printf("%d\n",i--);
printf("%d\n",-i++);
printf("%d\n",-i--);
} i<--8
i<--i+1
i<--i-1
i<--i+1
i<--i-1
i<--i+1
i<--i-1 int i=8;
printf("%d\n",++i);
printf("%d\n",--i);
printf("%d\n",i++);
printf("%d\n",i--);
printf("%d\n",-i++);
printf("%d\n",-i--); 

i的初值為8

第2行i加1后輸出故為9;

第3行減1后輸出故為8;

第4行輸出i為8之后再加1(為9);

第5行輸出i為9之后再減1(為8) ;

第6行輸出-8之后再加1(為9);

第7行輸出-9之后再減1(為8)

void main(){
int i=5,j=5,p,q;
p=(i++)+(i++)+(i++);
q=(++j)+(++j)+(++j);
printf("%d,%d,%d,%d",p,q,i,j);
}
i<--5,j<--5,p<--0,q<--0
i+i+i--->p,i+1-->i,i+1-->i,i+1-->i
j+1->j,j+1->j,j+1->j,j+j+j->q int i=5,j=5,p,q;
p=(i++)+(i++)+(i++);
q=(++j)+(++j)+(++j);

這個程序中,對P=(i++)+(i++)+(i++)應(yīng)理解為三個i相加,故P值為15。然后i再自增1三次相當(dāng)于加3故i的最后值為8。而對于q 的值則不然,q=(++j)+(++j)+(++j)應(yīng)理解為q先自增1,再參與運算,由于q自增1三次后值為8,三個8相加的和為24,j的最后值仍為8。算術(shù)表達(dá)式表達(dá)式是由常量、變量、函數(shù)和運算符組合起來的式子。 一個表達(dá)式有一個值及其類型, 它們等于計算表達(dá)式所得結(jié)果的值和類型。表達(dá)式求值按運算符的優(yōu)先級和結(jié)合性規(guī)定的順序進(jìn)行。 單個的常量、變量、函數(shù)可以看作是表達(dá)式的特例。

算術(shù)表達(dá)式[ ]

是由算術(shù)運算符和括號連接起來的式子, 以下是算術(shù)表達(dá)式的例子: a+b  (a*2)/c (x+r)*8-(a+b)/7  ++i sin(x)+sin(y)  (++i)-(j++)+(k--)

賦值運算符和賦值表達(dá)式[ ]

簡單賦值運算符和表達(dá)式,簡單賦值運算符記為“=”。由“= ”連接的式子稱為賦值表達(dá)式。其一般形式為: 變量=表達(dá)式 例如:

x=a+b

w=sin(a)+sin(b)

y=i+++--j 賦值表達(dá)式的功能是計算表達(dá)式的值再賦予左邊的變量。賦值運算符具有右結(jié)合性。因此

a=b=c=5

可理解為

a=(b=(c=5))

在其它高級語言中,賦值構(gòu)成了一個語句,稱為賦值語句。 而在C中,把“=”定義為運算符,從而組成賦值表達(dá)式。 凡是表達(dá)式可以出現(xiàn)的地方均可出現(xiàn)賦值表達(dá)式。例如,式子x=(a=5)+(b=8)是合法的。它的意義是把5賦予a,8賦予b,再把a,b相加,和賦予x ,故x應(yīng)等于13。

在C語言中也可以組成賦值語句,按照C語言規(guī)定, 任何表達(dá)式在其未尾加上分號就構(gòu)成為語句。因此如x=8;a=b=c=5;都是賦值語句,在前面各例中我們已大量使用過了。 如果賦值運算符兩邊的數(shù)據(jù)類型不相同, 系統(tǒng)將自動進(jìn)行類型轉(zhuǎn)換,即把賦值號右邊的類型換成左邊的類型。具體規(guī)定如下: 1.實型賦予整型,舍去小數(shù)部分。前面的例2.9已經(jīng)說明了這種情況。 2.整型賦予實型,數(shù)值不變,但將以浮點形式存放, 即增加小數(shù)部分(小數(shù)部分的值為0)。 3.字符型賦予整型,由于字符型為一個字節(jié), 而整型為二個字節(jié),故將字符的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); 本例表明了上述賦值運算中類型轉(zhuǎn)換的規(guī)則。a為整型,賦予實型量y值888后只取整數(shù)8。x為實型,賦予整型量b值322, 后增加了小數(shù)部分。字符型量c1賦予a變?yōu)檎?,整型量b賦予c2 后取其低八位成為字符型(b的低八位為01000010,即十進(jìn)制66,按ASCII碼對應(yīng)于字符B)。

復(fù)合賦值符及表達(dá)式[ ]

在賦值符“=”之前加上其它二目運算符可構(gòu)成復(fù)合賦值符。如 +=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=。 構(gòu)成復(fù)合賦值表達(dá)式的一般形式為: 變量 雙目運算符=表達(dá)式 它等效于 變量=變量 運算符 表達(dá)式 例如: a+=5 等價于a=a+5  x*=y+7 等價于x=x*(y+7)  r%=p 等價于r=r%p 復(fù)合賦值符這種寫法,對初學(xué)者可能不習(xí)慣, 但十分有利于編譯處理,能提高編譯效率并產(chǎn)生質(zhì)量較高的目標(biāo)代碼。逗號運算符和逗號表達(dá)式在

逗號運算符[ ]

C語言中逗號“,”也是一種運算符,稱為逗號運算符。 其功能是把兩個表達(dá)式連接起來組成一個表達(dá)式, 稱為逗號表達(dá)式。 其一般形式為: 表達(dá)式1,表達(dá)式2 其求值過程是分別求兩個表達(dá)式的值,并以表達(dá)式2的值作為整個逗號表達(dá)式的值。

void main(){
int a=2,b=4,c=6,x,y;
x=a+b,y=b+c;
printf("y=%d,x=%d",y,x);
}
a<--2,b<--4,c<--6,x<--0,y<--0
x<--a+b,y<---b+c 

本例中,y等于整個逗號表達(dá)式的值,也就是表達(dá)式2的值,x是第一個表達(dá)式的值。對于逗號表達(dá)式還要說明兩點: 1.逗號表達(dá)式一般形式中的表達(dá)式1和表達(dá)式2 也可以又是逗號表達(dá)式。例如: 表達(dá)式1,(表達(dá)式2,表達(dá)式3) 形成了嵌套情形。因此可以把逗號表達(dá)式擴展為以下形式: 表達(dá)式1,表達(dá)式2,…表達(dá)式n 整個逗號表達(dá)式的值等于表達(dá)式n的值。 2.程序中使用逗號表達(dá)式,通常是要分別求逗號表達(dá)式內(nèi)各表達(dá)式的值,并不一定要求整個逗號表達(dá)式的值。 3.并不是在所有出現(xiàn)逗號的地方都組成逗號表達(dá)式,如在變量說明中,函數(shù)參數(shù)表中逗號只是用作各變量之間的間隔符。

[Practice] //arithmeticint a,b,c;
float d;
a=11;
b=235;
c=a+b-a*b;
d=(float)c/(float)a;
a=c/a;'Vtable
a,2,0
b,2,0
c,2,0
d,4,0.0
of Vtable
'Vupdate
1,0;2,0;3,0
4,0.0
1,11
2,235
3,-2339
4,-212.636368
1,-212
of Vupdate
of Practice
[Practice] //1int a,b,c1,c2;
a=25;
b=3243;
c1=b/a;
c2=b%a;'Vtable
a,2,0
b,2,0
c1,2,0
c2,2,0
of Vtable
'Vupdate
1,0;2,0;3,0;4,0
1,25
2,3243
3,129
4,18
of Vupdate
of Practice
[Practice] //1int a,b,c;
a=25;
b=40;
c=a+b,c+35;'Vtable
a,2,0
b,2,0
c,2,0
of Vtable
'Vupdate
1,0;2,0;3,0
1,25
2,40
3,65
of Vupdate
of Practice