C++語言基礎(課堂PPT)_第1頁
C++語言基礎(課堂PPT)_第2頁
C++語言基礎(課堂PPT)_第3頁
C++語言基礎(課堂PPT)_第4頁
C++語言基礎(課堂PPT)_第5頁
已閱讀5頁,還剩491頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、.1鹽城工學院 惠為君.2C+概述 C+的特點 發展歷史和未來 (CC+(AT&T)Java(SUN)C#(MS) 與其它語言比較(7點): 面向對象的概念:數據的封裝和隱藏、繼承、多態 VC上機過程.3C+的字符集的字符集26個個小寫字母小寫字母 abcdefghijklmnopqrstuvwxyz 26個個大寫字母大寫字母 ABCDEFGHIJKLMNOPQRSTUVWXYZ 10個個阿拉伯數阿拉伯數字字 0 1 2 3 4 5 6 7 8 9 其他符號其他符號 + - * / = , . _ : ; ? | ! # % & () 空格空格 C+語言使用下列基本字符來構成詞

2、法單位:語言使用下列基本字符來構成詞法單位:結束.4第二章: 數據類型 運算符 表達式 2.1 VC+ 的數據類型計算機所處理的數據以一定形式存放在內計算機所處理的數據以一定形式存放在內存中,數據的存儲方式以及能夠進行的合存中,數據的存儲方式以及能夠進行的合法運算都與數據類型直接相關。法運算都與數據類型直接相關。C+的特的特點之一就是提供了豐富的數據類型,以便點之一就是提供了豐富的數據類型,以便處理各種不同的數據。處理各種不同的數據。數據類型總是與運數據類型總是與運算封裝在一起,本質上是面向對象的。算封裝在一起,本質上是面向對象的。本本章將簡要介紹章將簡要介紹C+中的數據類型及相關運中的數據類

3、型及相關運算,以及常量、變量、表達式、語句等,算,以及常量、變量、表達式、語句等,最后介紹簡單的輸入輸出方法。最后介紹簡單的輸入輸出方法。.5 2.1.1 關鍵字數據類型說數據類型說明符與修飾明符與修飾符符bool char wchar_t class const double enum float int long short signed struct union unsigned void volatile存儲類型說存儲類型說明符明符auto extern inline register static訪問說明符訪問說明符friend private protected public其它說

4、明符其它說明符asm explicit namespace operator template this typedef typename using virtual 語句與標號語句與標號break case catch continue default do else for goto if return switch throw try while 運算符及邏運算符及邏輯值輯值delete false new sizeof true.6 還有一些關鍵字本書未介紹:還有一些關鍵字本書未介紹: const_cast dynamic_cast reinterpret_cast static_ca

5、st export mutable typeid 下面可用一些關鍵字代替邏輯運算符:下面可用一些關鍵字代替邏輯運算符:and and_eq bitand bitorCompl not or or_eqXor xor_eq not_eq.72.1.2 標識符標識符標識符(標識符(IdentifierIdentifier,ID ID )是程序員定是程序員定義的義的“單詞單詞”,用來給變量、常量、數據類型、,用來給變量、常量、數據類型、函數等命名。函數等命名。合法標識符合法標識符由由字母或下劃線字母或下劃線開始開始,由,由字母、字母、數字、下劃線數字、下劃線組成,其有效組成,其有效長度為長度為1 1

6、3131個字個字符符,長度超過,長度超過3131個字符者只識別個字符者只識別前前3131個字符個字符,VC+VC+標識符長度為標識符長度為1 1247247個字符。個字符。建議使用有一定含義的英文單詞或拼音序建議使用有一定含義的英文單詞或拼音序列作標識符,以提高列作標識符,以提高可讀性可讀性;另外盡量不用下;另外盡量不用下劃線或雙下劃線打頭,以免與系統定義的關鍵劃線或雙下劃線打頭,以免與系統定義的關鍵字沖突。字沖突。ok.8標識符標識符例例: 判斷下面哪些是合法的標識符:判斷下面哪些是合法的標識符: MyFileSalary 94amountvoid94SalarySalary94$amoun

7、tf3.5Num_of_Student2.1.2結束.92.1.3 標點符號標點符號標點符號包括標點符號包括:#、( )、 ,、,、 :、:、 ;、;、 、 等。等。 標點符號的作用標點符號的作用:有一定的語法意義。如字符和字符串有一定的語法意義。如字符和字符串常量分別用常量分別用 和和 “ ”引起來。引起來。對語法符號起分隔作用。如對語法符號起分隔作用。如 ;等;等2.1.3結束.102.1.5 C+的基本數據類型的基本數據類型圖圖2-1 C+的的數據結構數據結構實實 型型 float雙精度型雙精度型 doubleC+的數的數據類型據類型基本數據基本數據類型類型非基本數非基本數據類型據類型數

8、組數組 type 指針指針 type *結構結構 struct聯合聯合 union枚舉枚舉 enum類類 class整整 型型 int字符型字符型 char邏輯型邏輯型 bool無值型無值型 void實實 型型ok.11 C+C+對基本數據類型也分別進行了封裝,稱對基本數據類型也分別進行了封裝,稱為為內置數據類型內置數據類型,內置數據類型不僅定義了數據,內置數據類型不僅定義了數據類型,類型,還定義了還定義了常用操作常用操作。本節僅介紹各種基本。本節僅介紹各種基本數據類型的定義,常用操作將在后面介紹。數據類型的定義,常用操作將在后面介紹。 C+C+為強類型語言,所有數據的使用嚴格遵從為強類型語言

9、,所有數據的使用嚴格遵從“先說明后使用先說明后使用”的原則,以便編譯器進行編譯。的原則,以便編譯器進行編譯。 整型整型用來存放整數,整數(有符號的整數)用來存放整數,整數(有符號的整數)在內存中存放的是它的補碼,無符號數沒有符在內存中存放的是它的補碼,無符號數沒有符號位,存放的就是原碼。整數占用的字節數與號位,存放的就是原碼。整數占用的字節數與機型有關,機型有關,3232位機上占用位機上占用4 4個字節。個字節。 .12 字符型字符型用來保存字符,存儲的是該字符的用來保存字符,存儲的是該字符的ASCIIASCII碼,碼,占用一個字節。如大寫字母占用一個字節。如大寫字母A A的的ASCIIASC

10、II碼為碼為6565,在對應的,在對應的一個字節中存放的就是一個字節中存放的就是6565。字符型數據從本質上說也是。字符型數據從本質上說也是整數,可以是任何一個整數,可以是任何一個8 8位二進制整數。位二進制整數。 由于漢語系字符很多,用由于漢語系字符很多,用ASCIIASCII字符集處理遠遠不夠,字符集處理遠遠不夠,因此又創立了雙字節字符集(因此又創立了雙字節字符集(DBCSDBCS:double-byte double-byte character setcharacter set),每個字符用兩個字節來編碼。為便于),每個字符用兩個字節來編碼。為便于軟件的國際化,國際上一些知名公司聯合制

11、定了新的寬軟件的國際化,國際上一些知名公司聯合制定了新的寬字節字符標準字節字符標準UnicodeUnicode。該標準中所有字符都是雙字。該標準中所有字符都是雙字節的,不同的語言和字符集分別占用其中一段代碼。這節的,不同的語言和字符集分別占用其中一段代碼。這種用統一編碼處理西文、中文及其它語言符號,就是種用統一編碼處理西文、中文及其它語言符號,就是unicodeunicode碼。碼。C+C+同時也支持寬字符類型(同時也支持寬字符類型(wchar_twchar_t),或),或稱雙字節字符型稱雙字節字符型。 .13 實型實型和和雙精度型雙精度型都用來存放實數,兩者表示的實數都用來存放實數,兩者表示

12、的實數精度不同。實數在內存中以規范化的浮點數存放,包括精度不同。實數在內存中以規范化的浮點數存放,包括尾數、數符和階碼。數的精度取決于尾數的位數,尾數、數符和階碼。數的精度取決于尾數的位數,32位位機上實型為機上實型為23位(因規范化數的數碼最高位恒為位(因規范化數的數碼最高位恒為1,不必,不必存儲,實際為存儲,實際為24位),雙精度為位),雙精度為52位。位。 邏輯型邏輯型也稱也稱布爾型布爾型,其取值為,其取值為true(邏輯真)和(邏輯真)和false(邏(邏輯假),存儲字節數在不同編譯系統中可能有所不同,輯假),存儲字節數在不同編譯系統中可能有所不同,VC+6.0中為中為1個字節。布爾型

13、在運算中可以和整型相互轉個字節。布爾型在運算中可以和整型相互轉化,化,false對應為對應為0,true對應為對應為1或非或非0無值型無值型主要用來說明函數的返回值類型,將在函數一章中主要用來說明函數的返回值類型,將在函數一章中具體介紹。具體介紹。 基本數據類型還可以加上一些修飾詞,包括:基本數據類型還可以加上一些修飾詞,包括:signed(有符號)、(有符號)、unsigned(無符號)、(無符號)、long(長)、(長)、short(短)。參見下表:(短)。參見下表:.142. 2結束 類類 型型名名 稱稱占用字節數占用字節數取取 值值 范范 圍圍bool布爾型布爾型 true, fals

14、e(signed) char有符號字符型有符號字符型1-128 127unsiged char無符號字符型無符號字符型10 255(signed) short (int)有符號短整型有符號短整型2-32768 32767unsigned short (int)無符號短整型無符號短整型20 65535(signed) int (signed)有符號整型有符號整型4-231 (231-1)unsigned (int)無符號整型無符號整型40 (232-1)(signed) long (int)有符號長整型有符號長整型4-231 (231-1)unsigned long (int)無符號長整型無符號

15、長整型40 (232-1)float實型實型4-1038 1038double雙精度型雙精度型8-10308 10308long double長雙精度型長雙精度型8-10308 10308void無值型無值型0無值無值VC+中所有基本數據類型所有基本數據類型.152.1.6 常量 在程序的執行過程中,值保持不變的量稱為 常量字面常量字面常量,指程序中直接給出的量;,指程序中直接給出的量;常量的值在程序執行過程中保持不變;并常量的值在程序執行過程中保持不變;并且且存儲在程序區存儲在程序區,而非數據區;,而非數據區;根據取值和表示方法的不同,可分為以下根據取值和表示方法的不同,可分為以下幾種:幾種

16、:.16a. a. 整形常量整形常量d. d. 字符串常量字符串常量c. c. 字符型常量字符型常量b. b. 實型常量實型常量ok.17a整型常量十進制表示法十進制表示法八進制表示法八進制表示法十六進制表示法十六進制表示法其他表示法其他表示法即整數,可以有多種表示方法:ok.18 整數的十進制表示方法十進制表示與我們熟悉的書寫方式相同。十進制表示與我們熟悉的書寫方式相同。如如15 -24ok.19 整數的八進制表示 八進制表示八進制表示以以0 0開始,由數字開始,由數字0 0 7 7組成組成,用來,用來表示一個八進制數。表示一個八進制數。如:如:012012 / /八進制數八進制數1212,

17、即十進制數,即十進制數1010-0655-0655/八進制數八進制數-655-655,即十進制數,即十進制數-429-429ok.20 整數的十六進制表示 十六進制十六進制以以0X0X(大小寫均可)開始,由數(大小寫均可)開始,由數字字0 0 9 9和字母和字母A A F F(大小寫均可)組成(大小寫均可)組成,用來,用來表示一個十六進制數。表示一個十六進制數。以下是一些以下是一些常整數常整數的例子:的例子:0 x32A /0 x32A /十六進制數十六進制數32A32A,即十進制數,即十進制數810810-0 x2fe0 /-0 x2fe0 /十六進制數十六進制數-2fe0-2fe0, /即

18、十進制數即十進制數-12256-12256ok.21整數的其他表示方法 整型常量還可以表示整型常量還可以表示長整數長整數和和無符號整數無符號整數。長整型常數以長整型常數以 L L 或或 l l 結尾,無符號常整數以結尾,無符號常整數以 U U 或或 u u 結尾,以結尾,以 U LU L 或或 L UL U(大小寫均可)(大小寫均可)結尾則可表示無符號長整型常數。結尾則可表示無符號長整型常數。例如:例如:-84L-84L/十進制長整數十進制長整數-84-84026U026U/八進制表示的無符號整數八進制表示的無符號整數26260X32LU /0X32LU /十六進制表示的無符號長整型數十六進制

19、表示的無符號長整型數3232。整數 結束 .22b實型常量( (1)1)一般形式一般形式與平時書寫形式相同,與平時書寫形式相同,由數字由數字 0 0 9 9和小數點組成和小數點組成。例如:。例如:0.23 -125.76 0.0 .46 -35.0.23 -125.76 0.0 .46 -35.(2) (2) 指數形式(也稱為科學表示法)指數形式(也稱為科學表示法)表示為表示為尾尾數乘以數乘以1010的次方形式,由的次方形式,由尾數尾數、E E或或e e和和階數階數組組成成。指數形式要求在。指數形式要求在E E或或e e前面的前面的尾數部分必須尾數部分必須有數字有數字,后面的,后面的指數部分必

20、須為整數指數部分必須為整數。 例例 : : 判斷下列表示是否合法判斷下列表示是否合法123E12 -.34e-2 E4 1.43E3.5 包含小數點和包含小數點和1010的冪的數為實型常量,有的冪的數為實型常量,有兩種表示方法:兩種表示方法:實數實數 結束結束.23c字符型常量 字符常量是用單引號引起來的單個字符字符常量是用單引號引起來的單個字符。在。在內存中保存的是字符的內存中保存的是字符的ASCIIASCII碼值。在所有字符碼值。在所有字符中,有些是可顯示字符,通常就用單引號引起中,有些是可顯示字符,通常就用單引號引起來表示:來表示:a a /字符字符a a /字符字符 44/字符字符4

21、4 /空格字符空格字符有些是特殊情況字符,如不可顯示的字符等,有些是特殊情況字符,如不可顯示的字符等,c+c+使用使用轉義序列轉義序列表示方法,如表示方法,如(祥見表祥見表2-32-3,此處略):此處略):n n /換行換行 / / 字符字符 字符常字符常 結束結束 .24d. 字符串常量字符串常量與字符型常量的區別字符串常量與字符型常量的區別字符串常量字符串常量aa占兩個字節,存放占兩個字節,存放aa和和 0 0,值為,值為0 x61000 x6100字符型常量字符型常量aa占一個字節,存放占一個字節,存放aa,值為,值為0 x610 x612.3.2結束結束用雙引號引起來的若干個字符稱為字

22、符串常量用雙引號引起來的若干個字符稱為字符串常量。例如例如:I am a Chinese.,123, a ,:I am a Chinese.,123, a , .252 標識符常量及常量說明符const用常量說明符用常量說明符constconst給字面常量起個名字(標識符),給字面常量起個名字(標識符),這個標識符就稱為這個標識符就稱為標識符常量標識符常量;因為標識符常量的說明和引用形式很像變量,所以也因為標識符常量的說明和引用形式很像變量,所以也稱稱常變量常變量;例如:;例如:constconst float PI=3.14159; float PI=3.14159;const const

23、int Number_of_Student=100; int Number_of_Student=100;常變量必須也只能在說明時進行初始化;常變量必須也只能在說明時進行初始化;常變量初始化之后,不允許再被賦值;常變量初始化之后,不允許再被賦值;常變量必須先說明后使用;常變量必須先說明后使用;常變量存儲在數據區,并且可以按地址訪問,編譯時常變量存儲在數據區,并且可以按地址訪問,編譯時系統對常變量進行類型檢查。系統對常變量進行類型檢查。C+C+建議使用常變量,而盡量不使用字面常量。建議使用常變量,而盡量不使用字面常量。2.3.3 結束結束.262.1.7 變 量1 1 變量說明變量說明 2 2

24、變量賦初值變量賦初值 變量變量,在程序中是指可以改變值的量;,在程序中是指可以改變值的量;變量必須用標識符進行標識,稱為變量必須用標識符進行標識,稱為變量名變量名;變量有變量有類型類型之分,如整形變量、字符變量等;之分,如整形變量、字符變量等;任何變量都必須任何變量都必須先說明后使用先說明后使用;一是便于編譯;一是便于編譯程序為變量分配空間,二是便于編譯時進行語程序為變量分配空間,二是便于編譯時進行語法檢查;法檢查;變量使用的第一步,是給變量賦變量使用的第一步,是給變量賦初始值初始值;ok.27變量說明 在在C+C+中,變量說明的一般格式為:中,變量說明的一般格式為:存儲類型存儲類型數據類型數

25、據類型 變量名變量名1 1, ,變量名變量名2, 2, , ,變量名變量名n n; 下面是變量說明的幾個例子:下面是變量說明的幾個例子:int i, j, k; /說明三個整型變量說明三個整型變量i, j, kfloat x, y, z; /說明三個實型變量說明三個實型變量x, y, zchar c1, c2; /說明兩個字符型變量說明兩個字符型變量c1, c2double dx; /說明一個雙精度型變量說明一個雙精度型變量dx 變量說明 結束 .28變量賦初值(1 1)變量說明時直接賦初值。變量說明時直接賦初值。例如:例如:int a=3, b=4, c=5;int a=3, b=4, c=

26、5;float x=3.0float x=3.0;(2 2)用賦值語句賦初值。用賦值語句賦初值。嚴格的說,只有前嚴格的說,只有前者可稱賦初值者可稱賦初值例如:例如:float x, e;float x, e;x=3.5; x=3.5; e=2.71828;e=2.71828;結束 給變量賦初值稱為初始化,有兩種方法:給變量賦初值稱為初始化,有兩種方法:.292.2 基本運算符 對常量和變量進行運算是通過運算符來實現的對常量和變量進行運算是通過運算符來實現的. 常量和常量和變量通過運算符組成變量通過運算符組成C+表達式表達式,由表達式再組成由表達式再組成C+語句語句. 運算符是完成對運算符是完成

27、對常量和變量進行運算的符號常量和變量進行運算的符號. 把參與運把參與運算的對象稱為操作數算的對象稱為操作數.按照要求的操作數的個數,運算符分為按照要求的操作數的個數,運算符分為單目單目(一元)運算(一元)運算符、符、雙目雙目(二元)運算符和(二元)運算符和三目三目(三元)運算符。(三元)運算符。單目運單目運算符算符只對一個操作數運算,如負號運算符只對一個操作數運算,如負號運算符“ ”等;等;雙目運雙目運算符算符要求有兩個操作數,如乘號運算符要求有兩個操作數,如乘號運算符“*”等;等;三目運算三目運算符符要求有三個操作數,三元運算符只有一個要求有三個操作數,三元運算符只有一個“?:”。.301.

28、算術運算符優先級優先級運算符運算符名名 稱稱3+正,單目正,單目 -負,單目負,單目5*乘,雙目乘,雙目 /除,雙目除,雙目 %求余,雙目求余,雙目6+加,雙目加,雙目 -減,雙目減,雙目ok.31運算符重載運算符重載:當兩個操作數均為整數時,當兩個操作數均為整數時,* *和和/ /重載為重載為整乘整乘和和整除整除,結果為整數,除法運算后舍去小數取整。如:結果為整數,除法運算后舍去小數取整。如:5/45/4/結果為結果為1 1,整數,整數當兩個操作數均為整數,當兩個操作數均為整數,%定義為定義為求余求余運算,也運算,也稱求模運算,結果為兩個整數相除后的余數。如稱求模運算,結果為兩個整數相除后的

29、余數。如果兩個整數中有負數,則先用兩數絕對值求余,果兩個整數中有負數,則先用兩數絕對值求余,最后結果的最后結果的符號與被除數相同符號與被除數相同。例如。例如6%3/結果為結果為06%7/結果為結果為67%6/結果為結果為1.32 C+ C+中算術運算應注意數據溢出問題,即運算中算術運算應注意數據溢出問題,即運算結果超出對應數據類型的表示范圍。結果超出對應數據類型的表示范圍。編譯程序只會編譯程序只會對除法運算時除數為對除法運算時除數為0 0這種情況提示出錯,這種情況提示出錯,而特別而特別容易溢出的整數的加、減和乘法運算產生溢出的情容易溢出的整數的加、減和乘法運算產生溢出的情況,系統不作為錯誤處理

30、,程序將繼續執行并產生況,系統不作為錯誤處理,程序將繼續執行并產生錯誤的計算結果。因此,程序設計者必須在程序中錯誤的計算結果。因此,程序設計者必須在程序中解決檢查并處理整數溢出問題。解決檢查并處理整數溢出問題。 只要有一個操作數是實數,兩個操作數均轉只要有一個操作數是實數,兩個操作數均轉換為換為doubledouble型,型,*和和/重載為普通的重載為普通的乘和除乘和除,結,結果果是實數是實數:5/4.05/4.0/結果為結果為1.251.25,實數,實數.332.關系運算符和邏輯運算符ok 關系運算符都是二元運算符,包括:關系運算符都是二元運算符,包括: (大于)、(大于)、(不小于)、(不

31、小于)、 (小于)、(小于)、(不小于)、(不小于)、= = =(等于)和?。ǖ扔冢┖?!= =(不等于)。關系運算符完成兩個操作數大小的比較,結(不等于)。關系運算符完成兩個操作數大小的比較,結果為邏輯值果為邏輯值true(true(真真) )或或falsefalse(假)(假)。每種。每種可比較大小可比較大小的數的數據類型,都據類型,都重載重載了關系運算符。不同類型,自動轉換為同了關系運算符。不同類型,自動轉換為同一類型后,采用對應關系運算符進行比較。一類型后,采用對應關系運算符進行比較。在在C+中這兩個邏輯值與整數之間有一個對應關系,真對中這兩個邏輯值與整數之間有一個對應關系,真對應應1,

32、假對應,假對應0;反過來,;反過來,0對應假,非對應假,非0整數對應真。整數對應真。所所以關系運算結果可以作為整數參與算術運算、關系運算、以關系運算結果可以作為整數參與算術運算、關系運算、邏輯運算及其他運算。邏輯運算及其他運算。.342.關系運算符和邏輯運算符設有定義設有定義 float a=3.2;int b=5; ;則則: : 3ab/結果是結果是?根據右結合根據右結合原則其運算原則其運算過程如下:過程如下:a5b3.23F, 即即0F即即0.35優優先先級級運運算算符符名名 稱稱語語 義義2!邏輯非邏輯非, 單目單目操作數的值為真,則結操作數的值為真,則結果為假果為假;12&邏輯

33、與邏輯與,雙目雙目當兩個操作數全為真時,當兩個操作數全為真時,結果為真,否則為假結果為真,否則為假;13|邏輯或邏輯或,雙目雙目兩個操作數中有一個為兩個操作數中有一個為真,則結果為真真,則結果為真;邏輯運算符邏輯運算符.36 邏輯運算符用來進行邏輯運算。其操作數和運邏輯運算符用來進行邏輯運算。其操作數和運算結果均為算結果均為邏輯量邏輯量。運算結果同樣可以作為一個。運算結果同樣可以作為一個整整數數參與其他運算。參與其他運算。 由于由于邏輯值邏輯值和和整數整數之間的之間的對應關系,對應關系,也允許也允許整型整型和和字符型字符型操作數進行操作數進行邏輯運算邏輯運算:21&021&0/

34、邏輯與,邏輯與,2121與與0 0,結果為假:,結果為假:0 021|021|0/邏輯或,邏輯或,2121或或0 0,結果為真:,結果為真:1 1!21!21/邏輯非,邏輯非,2121的非,結果為假:的非,結果為假:0 0邏輯運算符邏輯運算符.37 位運算符(1)按位取反運算符)按位取反運算符“” (2)左移運算符)左移運算符“” (4)按位與運算符)按位與運算符“&” (5)按位或運算符)按位或運算符“|” (6)按位異或運算符)按位異或運算符“” okc+c+語言提供字位運算,它對操作數的各個位進行操作。語言提供字位運算,它對操作數的各個位進行操作。.38(1 1)按位取反運算符)

35、按位取反運算符“”將操作數的每個二進制位取反,即將操作數的每個二進制位取反,即1 1變為變為0 0,0 0變為變為1 1。例如,。例如,整數整數a a的值為的值為1001101110011011,則,則aa的值為的值為0110010001100100。(2 2)左移運算符)左移運算符“”運算一般格式為:運算一般格式為:ana”與左移運算符類同,將左操作數向右移動右操作數指定的與左移運算符類同,將左操作數向右移動右操作數指定的二進制位數,忽略移位后的小數部分,并在高位補二進制位數,忽略移位后的小數部分,并在高位補0 0。一。一個整數右移個整數右移n n位相當于位相當于除以除以2 2的的n n次方

36、,但比除法快。次方,但比除法快。 在在VC+6.0VC+6.0中有符號數右移時高位補符號位,嚴格對應除中有符號數右移時高位補符號位,嚴格對應除法。法。以上三種單目運算不影響數據本身的值,而是只產生一以上三種單目運算不影響數據本身的值,而是只產生一個中間量,這個中間量被引用后即不再存在。個中間量,這個中間量被引用后即不再存在。 .39(4 4)按位與運算符)按位與運算符“&”&”將兩個操作數的對應位逐一進行按位邏輯與運算。運算規則將兩個操作數的對應位逐一進行按位邏輯與運算。運算規則為:對應位均為為:對應位均為1 1時,該位運算結果為時,該位運算結果為1 1;否則為;否則為0 0。

37、例如:。例如:a 01001101a 01001101b 00001111b 00001111a & b 00001101a & b 00001101該運算可用來將整數的某些位置該運算可用來將整數的某些位置0 0,而保留所需要的位,上例,而保留所需要的位,上例保留了低四位。保留了低四位。(5 5)按位或運算符)按位或運算符“|”|”將兩個操作數的對應位逐一進行按位邏輯或運算。運算規則將兩個操作數的對應位逐一進行按位邏輯或運算。運算規則為:只要有一個數對應位為為:只要有一個數對應位為1 1,該位運算結果即為,該位運算結果即為1 1;兩個數;兩個數對應位均為對應位均為0 0,該位結

38、果為,該位結果為0 0。例如:。例如:a 01001101a 01001101b 00001111b 00001111a | b 01001111a | b 01001111該運算符可用來將整數的某些位置該運算符可用來將整數的某些位置1 1。上例高四位不變,低四。上例高四位不變,低四位全位全1 1。.40(6 6)按位異或運算符)按位異或運算符“”將兩個操作數的對應位逐一進行按位異或運算。運算規則為:將兩個操作數的對應位逐一進行按位異或運算。運算規則為:當對應位的值不同時,該位運算結果為當對應位的值不同時,該位運算結果為1 1,否則為,否則為0 0。例如:。例如:a 01001101a 010

39、01101b 00001111b 00001111a b 01000010a b 01000010該運算符可用來將一個整數的某些位取反,或將整型變量的該運算符可用來將一個整數的某些位取反,或將整型變量的值置值置0 0(將整型變量與自身按位異或)。上例低四位取反,(將整型變量與自身按位異或)。上例低四位取反,高四位不變。高四位不變。需要說明的一點是,以上例子中的整數都只取了低需要說明的一點是,以上例子中的整數都只取了低8 8位一個位一個字節。字節。.414.賦值運算符ok 將數據存放到相應存儲單元中稱為將數據存放到相應存儲單元中稱為賦值賦值,如果,如果該單元中已有值,賦值操作以新值取代舊值;從該

40、單元中已有值,賦值操作以新值取代舊值;從某個存儲單元中取出數據使用,稱為引用,引用某個存儲單元中取出數據使用,稱為引用,引用不影響單元中的值,即一個量可以多次引用。不影響單元中的值,即一個量可以多次引用。常常量量只能引用,不能賦值。只能引用,不能賦值。 賦值通過賦值運算符賦值通過賦值運算符“=”來完成,其意義是將來完成,其意義是將賦值號右邊的值送到左邊變量所對應的單元中。賦值號右邊的值送到左邊變量所對應的單元中。賦值號不是等號,它具有方向性賦值號不是等號,它具有方向性。 .42C+C+將變量名代表的單元稱為將變量名代表的單元稱為 “左值左值”,而將變,而將變量的值稱為量的值稱為“右值右值”。

41、左值必須是內存中一個左值必須是內存中一個可以訪問且可以合法修改的對象可以訪問且可以合法修改的對象,因此只能是變,因此只能是變量名,量名,而不能是常量或表達式而不能是常量或表達式。4.賦值運算符例如下面的賦值運算是錯誤的:例如下面的賦值運算是錯誤的:3.1415926=pi;/左值不能是常數左值不能是常數x+y=z;/左值不能是表達式左值不能是表達式const int N=30;N=40;/左值不能是常變量左值不能是常變量.435.自增自減運算運算分前置和后置兩種,運算分前置和后置兩種,前置是先增減后引用前置是先增減后引用,即先,即先對變量自加或自減,用新的值參與其他運算;對變量自加或自減,用新

42、的值參與其他運算;后置則后置則是先引用后增減是先引用后增減,即用變量原來的值參與其他運算,即用變量原來的值參與其他運算,然后再對變量進行自加或自減然后再對變量進行自加或自減, ,例如:例如:int i=5, j=5, m, n;int i=5, j=5, m, n;m=i+;m=i+; / /后置;相當于后置;相當于m=i; i=i+1; m=i; i=i+1; / /結果:結果:i i的值為的值為6 6,m m的值為的值為5 5; ;n=+j;n=+j; / /前置;相當于前置;相當于j=j+1;n=j;j=j+1;n=j; / /結果:結果:j j的值為的值為6 6,n n的值為的值為6

43、6; ;意義:使變量當前值加意義:使變量當前值加1 1或減或減1 1,再賦給該變量。再賦給該變量。要求:操作數只能是要求:操作數只能是變量變量,不能是常量或表達式;,不能是常量或表達式;ok.44 sizeof( ) 運算符 用于計算一個操作數類型或一個變量的字用于計算一個操作數類型或一個變量的字節數。一般格式為:節數。一般格式為:sizeof (sizeof (數據類型數據類型) ) 或或 sizeof(sizeof(變量名變量名) ) 例如:例如:sizeof(int) 值為值為4 sizeof( float) 值為值為4double x; sizeof( x) 值為值為8 結束結束.45

44、2.2.2 表達式1 算術表達式算術表達式 2 關系表達式關系表達式 3 邏輯表達式和邏輯表達式求值的優化邏輯表達式和邏輯表達式求值的優化 4 賦值表達式與復合賦值表達式賦值表達式與復合賦值表達式 5 逗號表達式逗號表達式 ok.461.算術表達式使用時注意:使用時注意:1 1、表達式中每個變量都有確定的值時才能進、表達式中每個變量都有確定的值時才能進行表達式求值;行表達式求值;2 2、考慮到算術運算溢出和精度問題,應避免:、考慮到算術運算溢出和精度問題,應避免:(1 1)兩個很接近的數直接相減;)兩個很接近的數直接相減;(2 2)除數是一個很小的數;)除數是一個很小的數;(3 3)整數的連續

45、乘運算。)整數的連續乘運算。ok由算術運算符連接的表達式稱為算術表達式由算術運算符連接的表達式稱為算術表達式,例如:例如:a+b*3 ;.472.關系表達式例如:例如:abcabc / /* *等同于等同于(ab)c(ab)c,先求,先求ab ab 的值,的值, 再將結果再將結果0 0或或1 1與與c c比較大小比較大小* */ /a+bc+da+bc+d / /* *等同于等同于(a+b)(c+d)(a+b)(c+d), 結果為結果為0 0或或1 1* */ /y=aby=ab / /* *計算計算abab的值的值0 0或或1 1 賦給賦給y y,y y的值為的值為0 0或或1 1* */

46、/由關系運算符連接的表達式。值為由關系運算符連接的表達式。值為truetrue或或falsefalse。ok.483.邏輯表達式和邏輯表達式求值的優化由邏輯運算符連接的表達式稱為邏輯表達式。邏輯表達式的由邏輯運算符連接的表達式稱為邏輯表達式。邏輯表達式的值為值為truetrue或或falsefalse。這個值可對應整數。這個值可對應整數1 1或或0 0參與其他運算。參與其他運算。ok已知已知: int a=10, b=20, c=30;float x=1.8, y=2.4; ay|ab-!c按按優先級優先級與與結合性結合性,其,其求值順序求值順序等同于:等同于:(ay)|(a(b-(!c)t1

47、=1 t2=0t4=0 -&t3=0t5=bt6=1| 得整個表達式的值為:得整個表達式的值為:1 1.493.邏輯表達式和邏輯表達式求值的優化在求邏輯表達式值的過程中,一旦表達式的在求邏輯表達式值的過程中,一旦表達式的值能夠確定,就不再逐步進行下面的運算。值能夠確定,就不再逐步進行下面的運算。稱為稱為“求值優化求值優化”。已知已知: int a=10, b=20, c=30;求:求: ab | c+ /結果以及結果以及a,b,c的值的值t1=1整個表達式的值為整個表達式的值為 1 1可見可見: : 表達式表達式 c+ c+ 已不需要計算已不需要計算所以所以: : c不變仍為不變仍為

48、30編程人員在使用邏輯運算時應當加以小心,優化計算固然提編程人員在使用邏輯運算時應當加以小心,優化計算固然提高了運算效率,但可能產生副作用。高了運算效率,但可能產生副作用。所謂副作用,就是出乎所謂副作用,就是出乎設計人員的意料,得到預想不到的結果。設計人員的意料,得到預想不到的結果。.504.賦值表達式與復合賦值表達式 賦值表達式的格式為:賦值表達式的格式為: 變量變量 = = 表達式表達式 例如:例如:x=5+6;x=5+6;a=b=c=d+1a=b=c=d+1; ; 在在C+C+中,所有的雙目算術運算符和位運算符均可與中,所有的雙目算術運算符和位運算符均可與賦值運算符組合成一個單一運算符,

49、稱為賦值運算符組合成一個單一運算符,稱為復合運賦值復合運賦值算符算符。包括以下。包括以下1010個:個:+ = = * = / = % = = &= | = =復合賦值運算符的要求與格式與賦值運算符完全相同,復合賦值運算符的要求與格式與賦值運算符完全相同,表示為:表示為: 變量變量 復合賦值運算符復合賦值運算符 表達式表達式 它等同于它等同于 變量變量 = = 變量變量 運算符運算符 表達式表達式 例如:例如:x+=5x+=5 等同于:等同于:x=x+5x=x+5ok.51 逗號表達式 C+中,逗號既是分隔符,又是運算符,中,逗號既是分隔符,又是運算符,用逗號連接起來的表達式稱為逗號表

50、達式。用逗號連接起來的表達式稱為逗號表達式。 一般格式為:一般格式為:表達式表達式1,表達式,表達式2,表達式,表達式n 逗號表達式中的每一個表達式都會被運算,逗號表達式中的每一個表達式都會被運算,整個逗號表達式的值為最后一個表達式的值整個逗號表達式的值為最后一個表達式的值。例如:例如:a=(x=3,x+=6,5+6);/a=11 x=92.5.2結束結束.522.2.3不同類型數據的混合運算和賦值時的類型轉換1 1 不同類型數據的混合運算不同類型數據的混合運算 2 2 賦賦 值值 類類 型型 轉轉 換換 ok運算過程中,當某個二元運算符兩邊的操作數類型不同但運算過程中,當某個二元運算符兩邊的

51、操作數類型不同但屬于類型相容時,系統先將精度低的操作數變換到與另一屬于類型相容時,系統先將精度低的操作數變換到與另一操作數精度相同,而后再進行運算。操作數精度相同,而后再進行運算。 所謂類型相容,指的就是類型不同但系統可以所謂類型相容,指的就是類型不同但系統可以自動進行轉換。自動進行轉換。當賦值號的左值和右值類型不一致但屬于類型相容時,當賦值號的左值和右值類型不一致但屬于類型相容時,由系統自動進行類型轉換。由系統自動進行類型轉換。 .53具體規則如下:具體規則如下:(1 1)字符字符可以作為可以作為整數整數參與數值運算,參與數值運算,整數值為其整數值為其ASCIIASCII碼碼。(2 2)操作

52、數為字符或短整型時,系統自動變換成)操作數為字符或短整型時,系統自動變換成整型整型。(3 3)操作數為實型時,系統自動變換成)操作數為實型時,系統自動變換成雙精度型雙精度型。(4 4)其余情況,當兩操作數類型不同時,將精度低(或表示范)其余情況,當兩操作數類型不同時,將精度低(或表示范圍?。┑牟僮鲾档臄祿愋妥儞Q到與另一操作數類型相同再進圍?。┑牟僮鲾档臄祿愋妥儞Q到與另一操作數類型相同再進行運算行運算 例如有變量例如有變量: :char c1, c2; int i1, i2; float x1, x2;char c1, c2; int i1, i2; float x1, x2;則表達式則表達

53、式x2=c1x2=c1* *i1+c1i1+c1* *x1+c1x1+c1* *c2c2的求值過程為:將的求值過程為:將c1c1轉換成整型,完成轉換成整型,完成c1c1* *i1i1,結果表示為,結果表示為t1t1;將;將c1c1和和x1x1均轉換成雙精度型,完成均轉換成雙精度型,完成c1c1* *x1x1,結果表示為,結果表示為t2t2;將;將c1c1和和c2c2均轉換成整型,完成均轉換成整型,完成c1c1* *c2c2,結果表示為,結果表示為t3t3;然后然后t1t1轉換成雙精度型,完成轉換成雙精度型,完成t1+t2t1+t2,結果表示為,結果表示為t4t4;將;將t3t3轉換成雙精度型,

54、完成轉換成雙精度型,完成t4+t3t4+t3,最后結果轉為單精度型賦給,最后結果轉為單精度型賦給x2x2。 .542.賦值類型轉換2.5.3結束結束系統自動進行類型轉換規則:系統自動進行類型轉換規則:1 1、實型數賦給整形變量:取整;注意溢出;、實型數賦給整形變量:取整;注意溢出;2 2、整型數賦給實型變量:先轉換為實型數;、整型數賦給實型變量:先轉換為實型數;3 3、字符型數賦給整形變量:、字符型數賦給整形變量:ASCIIASCII碼為依據;碼為依據;分為兩種情況:符號位是分為兩種情況:符號位是0 0或或1 1時不同;時不同;若符號位為若符號位為1,則低位字節不變,高位字節全部置,則低位字節

55、不變,高位字節全部置1再賦值。再賦值。4 4、絕對值較大的數賦給表達范圍較小的數據、絕對值較大的數賦給表達范圍較小的數據類型時,注意溢出;類型時,注意溢出;.552.5.4 強制類型轉換運算符ok其格式為:其格式為: () () /形式一形式一或或 ()/形式二形式二作用:作用:將表達式強制轉換為將表達式強制轉換為類型,類型, 但表達式的值及其類型不變。但表達式的值及其類型不變。任意數據類型任意數據類型.56 賦值運算中,當左值與右值類型不一致時,賦值運算中,當左值與右值類型不一致時,系統將按照系統將按照左值左值的類型,的類型,自動自動進行強制轉換。進行強制轉換。例如例如: : 設有以下定義設

56、有以下定義 double x=2.3,y; int i=2,j;(1) j2.3x2.3 22(1) j=x;(2) y=i;由由系統系統按按左值左值j 、y類型類型自動自動完成強制完成強制轉換功能轉換功能 (2) y2i2 2.02.02.5.4 強制類型轉換運算符.57第三章: 簡單輸入/輸出 3.1 cin cin用來在程序執行期間給變量輸入數據,用來在程序執行期間給變量輸入數據, 一般格式為:一般格式為: cin變量名變量名1變量名變量名2變量名變量名n; cout實現將數據輸出到顯示器的操作,實現將數據輸出到顯示器的操作, 一般格式為:一般格式為: cout表達式表達式1表達式表達式

57、2表達式表達式n; 同時必須在程序開頭增加一行:同時必須在程序開頭增加一行: # include .583.1.1十進制數據的輸入輸出請看下例:請看下例:int i, j; float x, y;cout”Input i, j, x, y:”ij;/Dcinxy;cout”i=”it”j=”jendl;cout”x+y=”x+yendl; 若輸入:若輸入:10 20 4.5 8.6 則程序輸出:則程序輸出:i=10j=20 x+y=13.1輸出時各數據間是無間隔的,因此應當有意輸出一些輸出時各數據間是無間隔的,因此應當有意輸出一些間隔符間隔符 ok.59 3.1.2 輸入字符數據輸入字符數據

58、cin 與與cin.get( )的區別的區別 (1) cin 例如例如:char c1, c2, c3;cinc1;/Acinc2c3; 程序執行到程序執行到A行時,等待用戶輸入數據。行時,等待用戶輸入數據。 若輸入:若輸入:A b c 則則cin分別將字符分別將字符A、b、c賦給變量賦給變量c1、c2、c3。 cin自動跳過輸入的自動跳過輸入的空白空白字符(包括空格,制字符(包括空格,制表,表,backspace和回車等)。和回車等)。 .60 (2)cin.get() 例如:例如: char c1, c2, c3, c4;cin.get (c1);/Bcin.get (c2);cin.ge

59、t (c3); 程序執行到程序執行到B行時,若輸入:行時,若輸入:A b 則執行結果是:字符則執行結果是:字符A、空格、字符、空格、字符b分別賦給變量分別賦給變量c1、c2、c3;輸入行中仍;輸入行中仍保留回車符。保留回車符。cin.get()把從鍵盤上輸入的把從鍵盤上輸入的所有字符,包括所有字符,包括空白空白字符,都作為輸入字符,都作為輸入字符賦給字符變量字符賦給字符變量 .61 關于字符的輸出,請看下例,假定字符關于字符的輸出,請看下例,假定字符c1、c2、c3的值分別為字符的值分別為字符a、b和和c,執行以下語句,執行以下語句序列:序列: coutc1tc2n; coutc3endl;

60、coutOkendl; 屏幕上將輸出:屏幕上將輸出: ab c Ok 輸出時字符之間是無間隔的,如果想讓字符間輸出時字符之間是無間隔的,如果想讓字符間有間隔,必須輸出間隔符有間隔,必須輸出間隔符 .62補充.字符串輸入輸出向一個字符數組中輸入字符串時,用函數向一個字符數組中輸入字符串時,用函數getline() 。getline() 以用戶按下回車鍵作為結以用戶按下回車鍵作為結束,在此之前的所有輸入都放入字符數組中:束,在此之前的所有輸入都放入字符數組中:cin.getline (char ,int)其中第一個參數是已經定義的字符數組名,第其中第一個參數是已經定義的字符數組名,第二個參數是讀入字符的最多個數二個參數是讀入字符的最多個數n(包括字符(包括字符串結束符串結束符/0)。

溫馨提示

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

評論

0/150

提交評論