c語言運算符及其表達式_第1頁
c語言運算符及其表達式_第2頁
c語言運算符及其表達式_第3頁
c語言運算符及其表達式_第4頁
c語言運算符及其表達式_第5頁
已閱讀5頁,還剩42頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

c語言運算符及其表達式c語言運算符及其表達式/NUMPAGES47c語言運算符及其表達式c語言運算符及其表達式C語言的數(shù)據(jù)類型運算符表達式1.基本數(shù)據(jù)類型

基本數(shù)據(jù)類型最主要的特點是,其值不可以再分解為其它類型。也就是說,基本數(shù)據(jù)類型是自我說明的。

2.構(gòu)造數(shù)據(jù)類型構(gòu)造數(shù)據(jù)類型

是根據(jù)已定義的一個或多個數(shù)據(jù)類型用構(gòu)造的方法來定義的。也就是說,一個構(gòu)造類型的值可以分解成若干個“成員”或“元素”。每個“成員”都是一個基本數(shù)據(jù)類型或又是一個構(gòu)造類型。在C語言中,構(gòu)造類型有以下幾種:

·數(shù)組類型

·結(jié)構(gòu)類型

·聯(lián)合類型

3.指針類型

指針是一種特殊的,同時又是具有重要作用的數(shù)據(jù)類型。其值用來表示某個量在內(nèi)存儲器中的地址。雖然指針變量的取值類似于整型量,但這是兩個類型完全不同的量,因此不能混為一談。4.空類型在調(diào)用函數(shù)值時,通常應(yīng)向調(diào)用者返回一個函數(shù)值。這個返回的函數(shù)值是具有一定的數(shù)據(jù)類型的,應(yīng)在函數(shù)定義及函數(shù)說明中給以說明,例如在例題中給出的max函數(shù)定義中,函數(shù)頭為:intmax(inta,intb);其中“int”類型說明符即表示該函數(shù)的返回值為整型量。又如在例題中,使用了庫函數(shù)sin,由于系統(tǒng)規(guī)定其函數(shù)返回值為雙精度浮點型,因此在賦值語句s=sin(x);中,s也必須是雙精度浮點型,以便與sin函數(shù)的返回值一致。所以在說明部分,把s說明為雙精度浮點型。但是,也有一類函數(shù),調(diào)用后并不需要向調(diào)用者返回函數(shù)值,這種函數(shù)可以定義為“空類型”。其類型說明符為void。在第五章函數(shù)中還要詳細介紹。在本章中,我們先介紹基本數(shù)據(jù)類型中的整型、浮點型和字符型。其余類型在以后各章中陸續(xù)介紹。

對于基本數(shù)據(jù)類型量,按其取值是否可改變又分為常量和變量兩種。在程序執(zhí)行過程中,其值不發(fā)生改變的量稱為常量,取值可變的量稱為變量。它們可與數(shù)據(jù)類型結(jié)合起來分類。例如,可分為整型常量、整型變量、浮點常量、浮點變量、字符常量、字符變量、枚舉常量、枚舉變量。在程序中,常量是可以不經(jīng)說明而直接引用的,而變量則必須先說明后使用。整型量

整型量包括整型常量、整型變量。整型常量就是整常數(shù)。在C語言中,使用的整常數(shù)有八進制、十六進制和十進制三種。

整型常量

1.八進制整常數(shù)八進制整常數(shù)必須以0開頭,即以0作為八進制數(shù)的前綴。數(shù)碼取值為0~7。八進制數(shù)通常是無符號數(shù)。

以下各數(shù)是合法的八進制數(shù):

015(十進制為13)0101(十進制為65)0177777(十進制為65535)

以下各數(shù)不是合法的八進制數(shù):

256(無前綴0)03A2(包含了非八進制數(shù)碼)-0127(出現(xiàn)了負號)

2.十六進制整常數(shù)

十六進制整常數(shù)的前綴為0X或0x。其數(shù)碼取值為0~9,A~F或a~f。

以下各數(shù)是合法的十六進制整常數(shù):

0X2A(十進制為42)0XA0(十進制為160)0XFFFF(十進制為65535)

以下各數(shù)不是合法的十六進制整常數(shù):

5A(無前綴0X)0X3H(含有非十六進制數(shù)碼)

3.十進制整常數(shù)

十進制整常數(shù)沒有前綴。其數(shù)碼為0~9。

以下各數(shù)是合法的十進制整常數(shù):

237-568655351627

以下各數(shù)不是合法的十進制整常數(shù):

023(不能有前導(dǎo)0)23D(含有非十進制數(shù)碼)

在程序中是根據(jù)前綴來區(qū)分各種進制數(shù)的。因此在書寫常數(shù)時不要把前綴弄錯造成結(jié)果不正確。4.整型常數(shù)的后綴在16位字長的機器上,基本整型的長度也為16位,因此表示的數(shù)的范圍也是有限定的。十進制無符號整常數(shù)的范圍為0~65535,有符號數(shù)為-32768~+32767。八進制無符號數(shù)的表示范圍為0~0177777。十六進制無符號數(shù)的表示范圍為0X0~0XFFFF或0x0~0xFFFF。如果使用的數(shù)超過了上述范圍,就必須用長整型數(shù)來表示。長整型數(shù)是用后綴“L”或“l(fā)”來表示的。例如:

十進制長整常數(shù)158L(十進制為158)358000L(十進制為-358000)

八進制長整常數(shù)012L(十進制為10)077L(十進制為63)0200000L(十進制為65536)

十六進制長整常數(shù)0X15L(十進制為21)0XA5L(十進制為165)0X10000L(十進制為65536)

長整數(shù)158L和基本整常數(shù)158在數(shù)值上并無區(qū)別。但對158L,因為是長整型量,C編譯系統(tǒng)將為它分配4個字節(jié)存儲空間。而對158,因為是基本整型,只分配2個字節(jié)的存儲空間。因此在運算和輸出格式上要予以注意,避免出錯。無符號數(shù)也可用后綴表示,整型常數(shù)的無符號數(shù)的后綴為“U”或“u”。例如:358u,0x38Au,235Lu均為無符號數(shù)。前綴,后綴可同時使用以表示各種類型的數(shù)。如0XA5Lu表示十六進制無符號長整數(shù)A5,其十進制為165。

整型變量

整型變量可分為以下幾類:

1.基本型

類型說明符為int,在內(nèi)存中占2個字節(jié),其取值為基本整常數(shù)。

2.短整量

類型說明符為shortint或short'C110F1。所占字節(jié)和取值范圍均與基本型相同。

3.長整型

類型說明符為longint或long,在內(nèi)存中占4個字節(jié),其取值為長整常數(shù)。

4.無符號型

類型說明符為unsigned。

無符號型又可與上述三種類型匹配而構(gòu)成:

(1)無符號基本型類型說明符為unsignedint或unsigned。

(2)無符號短整型類型說明符為unsignedshort

(3)無符號長整型類型說明符為unsignedlong

各種無符號類型量所占的內(nèi)存空間字節(jié)數(shù)與相應(yīng)的有符號類型量相同。但由于省去了符號位,故不能表示負數(shù)。下表列出了TurboC中各類整型量所分配的內(nèi)存字節(jié)數(shù)及數(shù)的表示范圍。

類型說明符數(shù)的范圍分配字節(jié)數(shù)

int-32768~32767■■

shortint-32768~32767■■

signedint-32768~32767■■

unsignedint0~65535■■

longint-2147483648~2147483647■■■■

unsignedlong0~4294967295■■■■

整型變量的說明

變量說明的一般形式為:類型說明符變量名標識符,變量名標識符,...;例如:

inta,b,c;(a,b,c為整型變量)

longx,y;(x,y為長整型變量)

unsignedp,q;(p,q為無符號整型變量)在書寫變量說明時,應(yīng)注意以下幾點:

1.允許在一個類型說明符后,說明多個相同類型的變量。各變量名之間用逗號間隔。類型說明符與變量名之間至少用一個空格間隔。

2.最后一個變量名之后必須以“;”號結(jié)尾。

3.變量說明必須放在變量使用之前。一般放在函數(shù)體的開頭部分。

[Practice]//1inta,b;

shortintc;

shortd=100;

a=d-20;

b=a+d;

c=a+b+d;

d=d-a+c-b;'Vtable

a,2,0

b,2,0

c,2,0

d,2,100

ofVtable

'Vupdate

1,0;2,0

3,0

4,100

1,80

2,180

3,360

4,200

ofVupdate

ofPractice

[Practice]//2inta=5;

intb=9;

longintc;

longd;

c=a+b-7;

d=a*b*c;

c=d*d*d;

a=c-d;'Vtable

a,2,5

b,2,9

c,4,0

d,4,0

ofVtable

'Vupdate

1,5

2,9

3,0

4,0

3,7

4,315

3,31255875

1,-5112

ofVupdate

ofPractice

[Practice]//3inta=6,b=19;

unsignedintc;

intd;

c=a-b+7;

d=b*c;

a=b+c+d;

b=-a;'Vtable

a,2,6

b,2,19

c,2,0

d,2,0

ofVtable

'Vupdate

1,6;2,19

3,0

4,0

3,65530

4,-114

1,-101

2,101

ofVupdate

ofPractice

voidmain(){

longx,y;

inta,b,c,d;

x=5;

y=6;

a=7;

b=8;

c=x+a;

d=y+b;

printf("c=x+a=%d,d=y+b=%d\n",c,d);

}

將main說明為返回void,即不返回任何類型的值

x,y被定義為long型

a,b,c,d被定義為int型

5->x

6->y

7->a

8->b

x+a->c

y+b->d

顯示程序運行結(jié)果oflongx,y;

inta,b,c,d;

c=x+a;

d=y+b;

從程序中可以看到:x,y是長整型變量,a,b是基本整型變量。它們之間允許進行運算,運算結(jié)果為長整型。但c,d被定義為基本整型,因此最后結(jié)果為基本整型。本例說明,不同類型的量可以參與運算并相互賦值。其中的類型轉(zhuǎn)換是由編譯系統(tǒng)自動完成的。有關(guān)類型轉(zhuǎn)換的規(guī)則將在以后介紹。

實型量

實型常量

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

1.十進制數(shù)形式

由數(shù)碼0~9和小數(shù)點組成。例如:0.0,.25,5.789,0.13,5.0,300.,-267.8230等均為合法的實數(shù)。

2.指數(shù)形式

由十進制數(shù),加階碼標志“e”或“E”以及階碼(只能為整數(shù),可以帶符號)組成。其一般形式為aEn(a為十進制數(shù),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(階碼標志E之前無數(shù)字)-5(無階碼標志)53.-E3(負號位置不對)2.7E(無階碼)

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

voidmain()

{

printf("%f\n%f\n",356.,356f);

}

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

實型變量

實型變量分為兩類:單精度型和雙精度型,

其類型說明符為float單精度說明符,double雙精度說明符。在TurboC中單精度型占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ī)則與整型相同。

例如:floatx,y;(x,y為單精度實型量)

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

實型常數(shù)不分單、雙精度,都按雙精度double型處理。

voidmain()

{

floata;

doubleb;

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的不同

floata;

doubleb;

a=33333.33333;

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

[Practice]//floatinta=32;

floatb;

doubled;

b=12345678;

d=b*100;

d=d+a;

d=d+58.123456;'Vtable

a,2,32

b,4,0.0

d,8,0.0

ofVtable

'Vupdate

1,32

2,0

3,0

2,12345678.00000

3,1234567800

3,1234567832

3,1234567890.123456

ofVupdate

ofPractice

[Practice]//1inta=543;

floatb;

b=123.123962+a;

b=b-100;

a=b;'Vtable

a,2,543

b,4,0.0

ofVtable

'Vupdate

1,543

2,0.0

2,123.123962

2,23.123962

1,23

ofVupdate

ofPractice

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

字符常量

字符常量是用單引號括起來的一個字符。例如'a','b','=','+','?'都是合法字符常量。在C語言中,字符常量有以下特點:

1.字符常量只能用單引號括起來,不能用雙引號或其它括號。

2.字符常量只能是單個字符,不能是字符串。

3.字符可以是字符集中任意字符。但數(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鳴鈴

\ddd1~3位八進制數(shù)所代表的字符

\xhh1~2位十六進制數(shù)所代表的字符

廣義地講,C語言字符集中的任何一個字符均可用轉(zhuǎn)義字符來表示。表2.2中的\ddd和\xhh正是為此而提出的。ddd和hh分別為八進制和十六進制的ASCII代碼。如\101表示字?quot;A",\102表示字母"B",\134表示反斜線,\XOA表示換行等。轉(zhuǎn)義字符的使用

voidmain()

{

inta,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);

}

此程序練習轉(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ī)則都與整型變量相同。

例如:

chara,b;每個字符變量被分配一個字節(jié)的內(nèi)存空間,因此只能存放一個字符。字符值是以ASCII碼的形式存放在變量的內(nèi)存單元之中的。如x的

十進制ASCII碼是120,y的十進制ASCII碼是121。對字符變量a,b賦予'x'和'y'值:a='x';b='y';實際上是在a,b兩個單元內(nèi)存放120和121的二進制代碼:a01111000

b01111001

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

main()

{

chara,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ù)格式串中的格式符,當格式符為"c"時,對應(yīng)輸出的變量值為字符,當格式符為"d"時,對應(yīng)輸出的變量值為整數(shù)。

voidmain()

{

chara,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]//charinta=49;

charb;

chard;

b=a+10;

d=a+b;'Vtable

a,2,49

b,1,隨機

d,1,隨機

ofVtable

'Vupdate

1,49

2,隨機

3,隨機

2,';'

3,'l'

ofVupdate

ofPractice

[Practice]//charc1,c2;

c1='a';c2='b';

c1=c1-32;c2=c2-32;'Vtable

c1,1,隨機

c2,1,隨機

ofVtable

'Vupdate

1,隨機;2,隨機

1,'a';2,'b'

1,'A';2,'B'

ofVupdate

ofPractice

字符串常量

字符串常量是由一對雙引號括起的字符序列。例如:"CHINA","Cprogram:","$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é)束的標志。例如,字符串"Cprogram"在內(nèi)存中所占的字節(jié)為:Cprogram\0。字符常量'a'和字符串常量"a"雖然都只有一個字符,但在內(nèi)存中的情況是不同的。

'a'在內(nèi)存中占一個字節(jié),可表示為:a

"a"在內(nèi)存中占二個字節(jié),可表示為:a\0符號常量

符號常量

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

#define標識符常量

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

#definePI3.14159

voidmain()

{

floats,r;

r=5;

s=PI*r*r;

printf("s=%f\n",s);

}

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

顯示程序結(jié)果floats,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,……;例如:

inta=b=c=5;

floatx=3.2,y=3f,z=0.75;

charch1='K',ch2='P';

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

voidmain()

{

inta=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)換成同一類型,然后進行運算。

2.轉(zhuǎn)換按數(shù)據(jù)長度增加的方向進行,以保證精度不降低。如int型和long型運算時,先把int量轉(zhuǎn)成long型后再進行運算。

3.所有的浮點運算都是以雙精度進行的,即使僅含float單精度量運算的表達式,也要先轉(zhuǎn)換成double型,再作運算。

4.char型和short型參與運算時,必須先轉(zhuǎn)換成int型。

5.在賦值運算中,賦值號兩邊量的數(shù)據(jù)類型不同時,賦值號右邊量的類型將轉(zhuǎn)換為左邊量的類型。如果右邊量的數(shù)據(jù)類型長度左邊長時,將丟失一部分數(shù)據(jù),這樣會降低精度,丟失的部分按四舍五入向前舍入。圖21表示了類型自動轉(zhuǎn)換的規(guī)則。

voidmain()

{

floatPI=3.14159;

ints,r=5;

s=r*r*PI;

printf("s=%d\n",s);

}

PI<--3.14159

s<--0,r<--5

s<--r*r*PI

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

floatPI=3.14159;

ints,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)的。其一般形式為:(類型說明符)(表達式)其功能是把表達式的運算結(jié)果強制轉(zhuǎn)換成類型說明符所表示的類型。例如:(float)a把a轉(zhuǎn)換為實型(int)(x+y)把x+y的結(jié)果轉(zhuǎn)換為整型在使用強制轉(zhuǎn)換時應(yīng)注意以下問題:

1.類型說明符和表達式都必須加括號(單個變量可以不加括號),如把(int)(x+y)寫成(int)x+y則成了把x轉(zhuǎn)換成int型之后再與y相加了。

2.無論是強制轉(zhuǎn)換或是自動轉(zhuǎn)換,都只是為了本次運算的需要而對變量的數(shù)據(jù)長度進行的臨時性轉(zhuǎn)換,而不改變數(shù)據(jù)說明時對該變量定義的類型。

main()

{

floatf=5.75;

printf("(int)f=%d,f=%f\n",(int)f,f);

}

f<--5.75

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

基本運算符和表達式

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

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

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

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

1.算術(shù)運算符

用于各類數(shù)值運算。包括加(+)、減(-)、乘(*)、除(/)、求余(或稱模運算,%)、自增(++)、自減(--)共七種。

2.關(guān)系運算符

用于比較運算。包括大于(>)、小于(<)、等于(==)、大于等于(>=)、小于等于(<=)和不等于(!=)六種。

3.邏輯運算符

用于邏輯運算。包括與(&&)、或(||)、非(!)三種。

4.位操作運算符

參與運算的量,按二進制位進行運算。包括位與(&)、位或(|)、位非(~)、位異或(^)、左移(<<)、右移(>>)六種。

5.賦值運算符

用于賦值運算,分為簡單賦值(=)、復(fù)合算術(shù)賦值(+=,-=,*=,/=,%=)和復(fù)合位運算賦值(&=,|=,^=,>>=,<<=)三類共十一種。

6.條件運算符

這是一個三目運算符,用于條件求值(?:)。

7.逗號運算符

用于把若干表達式組合成一個表達式(,)。

8.指針運算符

用于取內(nèi)容(*)和取地址(&)二種運算。

9.求字節(jié)數(shù)運算符

用于計算數(shù)據(jù)類型所占的字節(jié)數(shù)(sizeof)。

10.特殊運算符

有括號(),下標[],成員(→,.)等幾種。

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

C語言中,運算符的運算優(yōu)先級共分為15級。1級最高,15級最低。在表達式中,優(yōu)先級較高的先于優(yōu)先級較低的進行運算。而在一個運算量兩側(cè)的運算符優(yōu)先級相同時,則按運算符的結(jié)合性所規(guī)定的結(jié)合方向處理。C語言中各運算符的結(jié)合性分為兩種,即左結(jié)合性(自左至右)和右結(jié)合性(自右至左)。例如算術(shù)運算符的結(jié)合性是自左至右,即先左后右。如有表達式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ù)表達式基本的算術(shù)運算符

1.加法運算符“+”加法運算符為雙目運算符,即應(yīng)有兩個量參與加法運算。如a+b,4+8等。具有右結(jié)合性。

2.減法運算符“-”減法運算符為雙目運算符。但“-”也可作負值運算符,此時為單目運算,如-x,-5等具有左結(jié)合性。

3.乘法運算符“*”雙目運算,具有左結(jié)合性。

4.除法運算符“/”雙目運算具有左結(jié)合性。參與運算量均為整型時,結(jié)果也為整型,舍去小數(shù)。如果運算量中有一個是實型,則結(jié)果為雙精度實型。

voidmain(){

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é)果也為實型。

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

voidmain(){

printf("%d\n",100%3);

}

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

自增1,自減1運算符

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

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

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

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

voidmain(){

inti=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-1inti=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)

voidmain(){

inti=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->qinti=5,j=5,p,q;

p=(i++)+(i++)+(i++);

q=(++j)+(++j)+(++j);

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

算術(shù)表達式

是由算術(shù)運算符和括號連接起來的式子,以下是算術(shù)表達式的例子:

a+b(a*2)/c(x+r)*8-(a+b)/7++isin(x)+sin(y)(++i)-(j++)+(k--)

賦值運算符和賦值表達式

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

x=a+b

w=sin(a)+sin(b)

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

a=b=c=5

可理解為

a=(b=(c=5))

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

在C語言中也可以組成賦值語句,按照C語言規(guī)定,任何表達式在其未尾加上分號就構(gòu)成為語句。因此如x=8;a=b=c=5;都是賦值語句,在前面各例中我們已大量使用過了。

如果賦值運算符兩邊的數(shù)據(jù)類型不相同,系統(tǒng)將自動進行類型轉(zhuǎn)換,即把賦值號右邊的類型換成左邊的類型。具體規(guī)定如下:

1.實型賦予整型,舍去小數(shù)部分。前面的例2.9已經(jīng)說明了這種情況。

2.整型賦予實型,數(shù)值不變,但將以浮點形式存放,即增加小數(shù)部分(小數(shù)部分的值為0)。

3.字符型賦予整型,由于字符型為一個字節(jié),而整型為二個字節(jié),故將字符的ASCII碼值放到整型量的低八位中,高八位為0。

4.整型賦予字符型,只把低八位賦予字符量。

voidmain(){

inta,b=322;

floatx,y=8.88;

charc1='k',c2;

a=y;

x=b;

a=c1;

c2=b;

printf("%d,%f,%d,%c",a,x,a,c2);

}

inta,b=322;

floatx,y=8.88;

charc1='k',c2;

printf("%d,%f,%d,%c",a=y,x=b,a=c1,c2=b);

本例表明了上述賦值運算中類型轉(zhuǎn)換的規(guī)則。a為整型,賦予實型量y值888后只取整數(shù)8。x為實型,賦予整型量b值322,后增加了小數(shù)部分。字符型量c1賦予a變?yōu)檎?,整型量b賦予c2后取其低八位成為字符型(b的低八位為01000010,即十進制66,按ASCII碼對應(yīng)于字符B)。

復(fù)合賦值符及表達式

在賦值符“=”之前加上其它二目運算符可構(gòu)成復(fù)合賦值符。如

+=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=。構(gòu)成復(fù)合賦值表達式的一般形式為:變量雙目運算符=表達式它等效于變量=變量運算符表達式例如:a+=5等價于a=a+5x*=y+7等價于x=x*(y+7)r%=p等價于r=r%p

復(fù)合賦值符這種寫法,對初學者可能不習慣,但十分有利于編譯處理,能提高編譯效率并產(chǎn)生質(zhì)量較高的目標代碼。逗號運算符和逗號表達式在

逗號運算符

C語言中逗號“,”也是一種運算符,稱為逗號運算符。其功能是把兩個表達式連接起來組成一個表達式,稱為逗號表達式。

其一般形式為:表達式1,表達式2其求值過程是分別求兩個表達式的值,并以表達式2的值作為整個逗號表達式的值。

voidmain(){

inta=2,b=4,c=6,x,y;

x=a+b,y=b+c;

printf("

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論