第2章數據類型、運算符和表達式
【考點一】 C+ +語言的數據類型
C+ +中的數據類型大體可以分成三類,它們是:基本類型、導出類型和用戶定義類型。基本類型是由C+ +語言預先定義好的數據類型,它包括:邏輯型、字符型、整型、浮點型和空值型。導出類型是由某種已知類型構造出來的數據類型,它包括:數組、指針和引用。用戶定義類型是指必須由用戶給出具體定義后才能使用的數據類型,它包括:枚舉類型和類類型。
1.基本類型
(1)邏輯型邏輯型用關鍵字bool表示,因此又稱為bool型(布爾型)。邏輯型的取值范圍只包含true和false,它們都是C+ +關鍵字。
(2)字符型〗字符型用關鍵字char表示,因此又稱為char型,即把字符作為一種數據進行操作。字符型的取值范圍是全部基本字符以及ASCII碼集或擴充ASCII碼集對應的全部符號。
(3)整型整型用關鍵字int表示,因此又稱為int型,它是C+ +中最常用的數據類型,整型數據的取值范圍是計算機所能表示的所有整數。
(4)浮點型浮點型包括單精度型和雙精度型兩種,單精度型用關鍵字float表示,又稱float型;雙精度型用關鍵字double表示,又稱double型。它們對應著數學中實數的概念,即帶有小數點的數。浮點型數據的取值范圍原則上是任意大小和精度的小數,但實際上不可能是任意大小的,而是有一定范圍的。C+ +中的浮點數可以采用尾數加階碼的表示形式,表示的浮點數范圍是:單精度型-3.4E38~3.4E38,但不能超過7位有效數字;雙精度型-1.7977E308~1.7977E308 ,但不能超過15位有效數字。
(5)空值型空值型用關鍵字void表示,因此又稱為void型。空值型的取值為空。C+ +中不存在void型的常量或變量。C+ +語言規定,所有函數說明都必須指明返回值類型,沒有返回值的函數應說明為void類型的函數;另外,void類型還可以用來聲明一個指針變量。
2.基本類型的派生類型C+ +語言中,基本類型的字長及其取值范圍可以放大和縮小,改變后的類型就叫做基本類型的派生類型。派生類型聲明符是由基本類型關鍵字char、int、float、double前面加上類型修飾符組成的。類型修飾符包括:short短類型,縮短字長;long長類型,加長字長;signed有符號類型,取值范圍包括正負值;unsigned無符號類型,取值范圍只包括正值; 【考點二】 常量常量是指在程序執行過程中值不改變的量。常量有兩種表示形式,即字面常量和符號常量。字面常量的類型是根據書寫形式來區分的,它們的類型分別為:整型、浮點型、字符型、字符串型,每個字面常量的字面本身就是它的值。符號常量是一個標識符,在程序中必須遵循"先聲明,后使用"的原則。
1.邏輯常量邏輯常量主要用在邏輯運算中,此外,由于邏輯值對應著整數1或0,所以它也能夠像其他整數一樣出現在表達式中,參與各種整數運算。
2.字符常量字符常量簡稱字符,它以單引號作為起止符號,中間有一個或若干個字符。這是一般意義上的字符常量;除此之外還有一種特殊形式的字符常量,以"\"開頭的包括多個字符的字符序列也是符合規定的字符常量。但是,無論字符常量包含一個還是多個字符,每個字符常量只能表示一個字符,當字符常量的一對單引號內多于一個字符時,則將按照一定的規則解釋為一個字符。計算機中常用的ASCII字符也是字符型的數據,因為ASCII碼值在0~127之間,正好落在字符型數據的取值范圍之內。ASCII字符集中的每一個顯示字符(個別字符除外)都可以作為一個字符常量。但是,對于一些特殊的字符,如回車、換行等具有控制功能的字符,或者像單引號、雙引號等作為特殊標記使用的字符,就無法直接采用單引號作為起止符號來表示。C+ +中引入了"轉義"字符的概念,其含義是:用反斜線"\"引導的下一個字符失去了原來的含義,而轉義為具有某種控制功能的字符。另外,還允許用反斜線引導一個具有1至3位的八進制整數或一個以字母x(大、小寫均可)作為開始標記的具有1至2位的十六進制整數,對應的字符就是以這個整數作為ASCII碼的字符。
3.整型常量整型常量就是整型常數,簡稱整數,它有十進制、八進制和十六進制3種表示。(1)十進制整數十進制整數以正號(+)或負號(-)開頭,由首位非0的一串十進制數字組成。若以正號開頭則為正數,若以負號開頭則為負數,若省略正負號,則默認為正數。當一個十進制整數大于等于-2 147 483 648(即231),同時小于等于2 147 483 647(即-231-1)時,則被系統看作是整型常量;當在2 147 483 648~4 294 967 295即232-1范圍之內時,則被看作是無符號整型常量;當超過上述兩個范圍時,則無法用C+ +整數類型表示,只有把它用實數(即帶小數點的數)表示才能夠被有效地存儲和處理。(2)八進制整數八進制整數以數字0開頭,后面接若干個八進制數字(借用十進制數字中的0~7)。八進制整數前面不帶正負號,全部默認為正數。當一個八進制整數大于等于0同時小于等于0時,則稱為整型常量,當大于等于020000000000同時小于等于037777777777時,則稱為無符號整型數量。不要使用超過上述兩個范圍的八進制整數,因為沒有與此相對應的C+ +整數類型。(3)十六進制整數十六進制整數以數字0和字母x(大、小寫均可)開頭,后面接若干個十六進制數字(借用十進制數字0~9,字母A~F或a~f)。當一個十六進制整數大于等于0同時小于等于0x7FFFFFFF時,則稱為整型常量,當大于等于0x80000000同時小于等于0xFFFFFFFF時,則稱為無符號整型常量,與八進制整數類似,超過上述兩個范圍的十六進制整數也沒有與之相對應的C+ +整數類型,所以也不能使用它們。C+ +中的整型數據除了一般表示方法之外,還允許給它們添加后綴u或l。對于任一種進制的整數,若后綴為字母u(大、小寫均可),則規定它為一個無符號整型(unsigned int)數,若后綴為字母l(大、小寫均可),則規定它為一個長整型(long int)數。在一個整數的末尾,可以同時使用u和l,并且對排列無要求。
4.實型常量實型常量有十進制的定點和浮點兩種表示方法,但并不存在其他進制的表示,下面分別介紹這兩種表示方法。(1)定點表示定點表示的實數簡稱定點數,實際上是以小數形式表示實數。定點表示的實數是由一個正號或負號(正號可以省略)后接若干個十進制數字和一個小數點所組成,這個小數點可以處在任何一個數字位的前面或后面。(2)浮點表示浮點表示的實數簡稱浮點數,實際上是以指數形式表示實數。浮點表示的實數是由一個十進制整數或定點數后接一個字母E(大、小寫均可)和一個1至3位的十進制整數所組成,字母E之前的部分稱為該浮點數的尾數,之后的部分成為該浮點數的指數,該浮點數的值就是它的尾數乘以10的指數冪。對于一個浮點數,若將它尾數中的小數點調整到最左邊第一個非零數字的后面,則稱它為規格化(或標準化)浮點數。實型常量分為單精度(float)、雙精度(double)和長雙精度(long double)三類。一般float型數據在內存中占4個字節,提供7位有效數字;double型數據占8個字節,提供15位有效數字;long double型數據占10個字節,提供19位有效數字。對于一個定點數或浮點數,C+ +自動按一個雙精度數(double型)來存儲。若在一個定點數或浮點數之后加上字母F(大、小寫均可),則自動按一個單精度數來存儲。
5.枚舉常量枚舉常量是枚舉類型中定義的值,即枚舉植。枚舉類型屬于用戶定義類型,用關鍵字enum表示,因此又稱為enum類型。用戶通常利用枚舉類型定義程序中需要使用的一組相關符號常量。聲明枚舉類型的語法格式為:enum<類型名>{<枚舉值表>};
其中,enum是關鍵字,指出要定義的是枚舉類型。<類型名>是標識符,即由用戶給出的具體枚舉類型名。<枚舉值表>包含多個枚舉值,它們用逗號分隔開,每個枚舉值就是一個枚舉常量。枚舉值有兩種定義形式:一是<值名>;二是<值名>=<整型常量>。
關于enum類型有四點說明:(1)一個enum類型實際上是int類型的一個子集,其每一個枚舉值代表一個整數。(2)n個枚舉值全部未賦常量值時,它們自左至右分別與整數0,1…n-1對應。(3)若第i個枚舉值賦常量值為m,則其未賦常量值的后續枚舉值分別與整數m+1,m+2…對應,直到下一個賦了值的枚舉值或結束。因此,為枚舉值所賦的整型常量值應從左至右遞增。(4)枚舉類型的聲明也可作為成組聲明若干整型符號常量的方法。也就是說,把每個要聲明的符號常量作為一個枚舉值,將各個枚舉值合在一起定義成一個枚舉類型。由于枚舉類型屬于用戶定義數據類型,一旦枚舉類型被定義后就可以使用它來定義變量。 【考點三】 變量
1.變量的定義變量的定義是通過變量聲明語句來實現的,變量聲明語句的一般格式為:[<存儲類>]<類型名><變量名>[=<初值表達式>],...;<存儲類>有四種,它們分別是auto、register、static、extern。<類型名>為已存在的一種數據類型名稱,如char,short,int,long,float,double等基本數據類型名,或者用戶定義的數據類型名。<變量名>是用戶定義的一個標識符,用來表示一個變量,該變量可以通過后面的可選項賦予一個值,稱為給變量賦初值,也叫做對變量進行初始化。C+ +中標識符是區分大小寫的,也就是說,大寫字母和小寫字母被認為是不同的字母。變量名的命名遵循如下規則:(1) 不能是C+ +關鍵字;(2)第一個字符必須是字母或下劃線;(3)中間不能有空格;(4)變量名中不能包括;,′″+-之類的特殊符號。實際上變量名中除了能使用26個英文大小寫字母和數字外,只能使用下劃線"_"。
2.變量的使用方式(1)全局變量和局部變量全局變量是在所有函數定義、類定義和程序塊之外聲明的變量。聲明全局變量時如果在程序中不對它進行專門的初始化,該變量會被系統自動初始化為0。在程序的任何一個函數、類或程序塊之內均可以訪問全局變量。局部變量是在某個函數定義、類定義或程序塊之內聲明的變量。局部變量只能在聲明它的函數、類或程序塊中被訪問。 (2)生存期與作用域生存期是指從一個變量被聲明且分配了內存開始,直到該變量聲明語句失效,它占用的內存空間被釋放為止。一個全局變量的生存期從它被聲明開始,直到程序結束;一個局部變量的生存期從它被聲明開始,直到包含它的最近的一個程序塊結束。作用域是指變量名可以代表該變量存儲空間的使用范圍。一般情況下,變量的作用域與其生存期一致,但由于C+ +語言允許在程序的不同部分為不同變量取同一名字,因此一個變量名的作用域可能小于其生存期。(3)變量的存儲類屬性在C+ +中變量還可以按存儲分配方式的不同被劃分為4種不同的存儲類別,它們分別是:①auto變量:用關鍵字auto聲明的局部變量稱為自動變量。auto為變量聲明時的默認存儲類別,即在變量定義時,如果不顯式標明存儲類別,則系統自動按auto變量處理。auto變量所占用存儲空間的分配和釋放工作將由系統自動完成。②register變量:用關鍵字register聲明的局部變量稱為寄存器變量。register變量可能以寄存器作為其存儲空間。聲明寄存器變量時,關鍵字register的作用只能是建議(而不是強制)系統使用寄存器,原因是寄存器雖然存取速度快,但空間有限,當寄存器不夠用時,該變量仍然按自動變量處理。③static變量:用關鍵字static聲明的變量稱為靜態變量。任何靜態變量的生存期將延續到整個程序的終止。與全局變量一樣,為靜態變量分配的存儲空間在整個程序運行過程中不再被釋放;如果靜態變量未被賦初值,系統將自動為其賦初值為0。④extern變量:用關鍵字extern聲明的變量稱為外部變量。變量一旦被聲明為外部變量,系統就不必像一般變量那樣為其分配內存,因為該變量已在這一局部的外面被定義。外部變量一般用于多個文件組成的程序中,有些變量在多個文件中被聲明,但卻是指同一變量。標明某一變量為外部變量可以避免為其重復分配內存。(4)typedef類型說明使用關鍵字typedef可以為已有類型名定義一個新類型名。其語法格式為:typedef<已有類型名><新類型名>typedef類型說明并沒有真正地定義新的數據類型,它只是相當于給某個已有的數據類型起了一個別名。在規模較大的程序中為了提高代碼可讀性常采用這種形式
【考點一】 C+ +語言的數據類型
C+ +中的數據類型大體可以分成三類,它們是:基本類型、導出類型和用戶定義類型。基本類型是由C+ +語言預先定義好的數據類型,它包括:邏輯型、字符型、整型、浮點型和空值型。導出類型是由某種已知類型構造出來的數據類型,它包括:數組、指針和引用。用戶定義類型是指必須由用戶給出具體定義后才能使用的數據類型,它包括:枚舉類型和類類型。
1.基本類型
(1)邏輯型邏輯型用關鍵字bool表示,因此又稱為bool型(布爾型)。邏輯型的取值范圍只包含true和false,它們都是C+ +關鍵字。
(2)字符型〗字符型用關鍵字char表示,因此又稱為char型,即把字符作為一種數據進行操作。字符型的取值范圍是全部基本字符以及ASCII碼集或擴充ASCII碼集對應的全部符號。
(3)整型整型用關鍵字int表示,因此又稱為int型,它是C+ +中最常用的數據類型,整型數據的取值范圍是計算機所能表示的所有整數。
(4)浮點型浮點型包括單精度型和雙精度型兩種,單精度型用關鍵字float表示,又稱float型;雙精度型用關鍵字double表示,又稱double型。它們對應著數學中實數的概念,即帶有小數點的數。浮點型數據的取值范圍原則上是任意大小和精度的小數,但實際上不可能是任意大小的,而是有一定范圍的。C+ +中的浮點數可以采用尾數加階碼的表示形式,表示的浮點數范圍是:單精度型-3.4E38~3.4E38,但不能超過7位有效數字;雙精度型-1.7977E308~1.7977E308 ,但不能超過15位有效數字。
(5)空值型空值型用關鍵字void表示,因此又稱為void型。空值型的取值為空。C+ +中不存在void型的常量或變量。C+ +語言規定,所有函數說明都必須指明返回值類型,沒有返回值的函數應說明為void類型的函數;另外,void類型還可以用來聲明一個指針變量。
2.基本類型的派生類型C+ +語言中,基本類型的字長及其取值范圍可以放大和縮小,改變后的類型就叫做基本類型的派生類型。派生類型聲明符是由基本類型關鍵字char、int、float、double前面加上類型修飾符組成的。類型修飾符包括:short短類型,縮短字長;long長類型,加長字長;signed有符號類型,取值范圍包括正負值;unsigned無符號類型,取值范圍只包括正值; 【考點二】 常量常量是指在程序執行過程中值不改變的量。常量有兩種表示形式,即字面常量和符號常量。字面常量的類型是根據書寫形式來區分的,它們的類型分別為:整型、浮點型、字符型、字符串型,每個字面常量的字面本身就是它的值。符號常量是一個標識符,在程序中必須遵循"先聲明,后使用"的原則。
1.邏輯常量邏輯常量主要用在邏輯運算中,此外,由于邏輯值對應著整數1或0,所以它也能夠像其他整數一樣出現在表達式中,參與各種整數運算。
2.字符常量字符常量簡稱字符,它以單引號作為起止符號,中間有一個或若干個字符。這是一般意義上的字符常量;除此之外還有一種特殊形式的字符常量,以"\"開頭的包括多個字符的字符序列也是符合規定的字符常量。但是,無論字符常量包含一個還是多個字符,每個字符常量只能表示一個字符,當字符常量的一對單引號內多于一個字符時,則將按照一定的規則解釋為一個字符。計算機中常用的ASCII字符也是字符型的數據,因為ASCII碼值在0~127之間,正好落在字符型數據的取值范圍之內。ASCII字符集中的每一個顯示字符(個別字符除外)都可以作為一個字符常量。但是,對于一些特殊的字符,如回車、換行等具有控制功能的字符,或者像單引號、雙引號等作為特殊標記使用的字符,就無法直接采用單引號作為起止符號來表示。C+ +中引入了"轉義"字符的概念,其含義是:用反斜線"\"引導的下一個字符失去了原來的含義,而轉義為具有某種控制功能的字符。另外,還允許用反斜線引導一個具有1至3位的八進制整數或一個以字母x(大、小寫均可)作為開始標記的具有1至2位的十六進制整數,對應的字符就是以這個整數作為ASCII碼的字符。
3.整型常量整型常量就是整型常數,簡稱整數,它有十進制、八進制和十六進制3種表示。(1)十進制整數十進制整數以正號(+)或負號(-)開頭,由首位非0的一串十進制數字組成。若以正號開頭則為正數,若以負號開頭則為負數,若省略正負號,則默認為正數。當一個十進制整數大于等于-2 147 483 648(即231),同時小于等于2 147 483 647(即-231-1)時,則被系統看作是整型常量;當在2 147 483 648~4 294 967 295即232-1范圍之內時,則被看作是無符號整型常量;當超過上述兩個范圍時,則無法用C+ +整數類型表示,只有把它用實數(即帶小數點的數)表示才能夠被有效地存儲和處理。(2)八進制整數八進制整數以數字0開頭,后面接若干個八進制數字(借用十進制數字中的0~7)。八進制整數前面不帶正負號,全部默認為正數。當一個八進制整數大于等于0同時小于等于0時,則稱為整型常量,當大于等于020000000000同時小于等于037777777777時,則稱為無符號整型數量。不要使用超過上述兩個范圍的八進制整數,因為沒有與此相對應的C+ +整數類型。(3)十六進制整數十六進制整數以數字0和字母x(大、小寫均可)開頭,后面接若干個十六進制數字(借用十進制數字0~9,字母A~F或a~f)。當一個十六進制整數大于等于0同時小于等于0x7FFFFFFF時,則稱為整型常量,當大于等于0x80000000同時小于等于0xFFFFFFFF時,則稱為無符號整型常量,與八進制整數類似,超過上述兩個范圍的十六進制整數也沒有與之相對應的C+ +整數類型,所以也不能使用它們。C+ +中的整型數據除了一般表示方法之外,還允許給它們添加后綴u或l。對于任一種進制的整數,若后綴為字母u(大、小寫均可),則規定它為一個無符號整型(unsigned int)數,若后綴為字母l(大、小寫均可),則規定它為一個長整型(long int)數。在一個整數的末尾,可以同時使用u和l,并且對排列無要求。
4.實型常量實型常量有十進制的定點和浮點兩種表示方法,但并不存在其他進制的表示,下面分別介紹這兩種表示方法。(1)定點表示定點表示的實數簡稱定點數,實際上是以小數形式表示實數。定點表示的實數是由一個正號或負號(正號可以省略)后接若干個十進制數字和一個小數點所組成,這個小數點可以處在任何一個數字位的前面或后面。(2)浮點表示浮點表示的實數簡稱浮點數,實際上是以指數形式表示實數。浮點表示的實數是由一個十進制整數或定點數后接一個字母E(大、小寫均可)和一個1至3位的十進制整數所組成,字母E之前的部分稱為該浮點數的尾數,之后的部分成為該浮點數的指數,該浮點數的值就是它的尾數乘以10的指數冪。對于一個浮點數,若將它尾數中的小數點調整到最左邊第一個非零數字的后面,則稱它為規格化(或標準化)浮點數。實型常量分為單精度(float)、雙精度(double)和長雙精度(long double)三類。一般float型數據在內存中占4個字節,提供7位有效數字;double型數據占8個字節,提供15位有效數字;long double型數據占10個字節,提供19位有效數字。對于一個定點數或浮點數,C+ +自動按一個雙精度數(double型)來存儲。若在一個定點數或浮點數之后加上字母F(大、小寫均可),則自動按一個單精度數來存儲。
5.枚舉常量枚舉常量是枚舉類型中定義的值,即枚舉植。枚舉類型屬于用戶定義類型,用關鍵字enum表示,因此又稱為enum類型。用戶通常利用枚舉類型定義程序中需要使用的一組相關符號常量。聲明枚舉類型的語法格式為:enum<類型名>{<枚舉值表>};
其中,enum是關鍵字,指出要定義的是枚舉類型。<類型名>是標識符,即由用戶給出的具體枚舉類型名。<枚舉值表>包含多個枚舉值,它們用逗號分隔開,每個枚舉值就是一個枚舉常量。枚舉值有兩種定義形式:一是<值名>;二是<值名>=<整型常量>。
關于enum類型有四點說明:(1)一個enum類型實際上是int類型的一個子集,其每一個枚舉值代表一個整數。(2)n個枚舉值全部未賦常量值時,它們自左至右分別與整數0,1…n-1對應。(3)若第i個枚舉值賦常量值為m,則其未賦常量值的后續枚舉值分別與整數m+1,m+2…對應,直到下一個賦了值的枚舉值或結束。因此,為枚舉值所賦的整型常量值應從左至右遞增。(4)枚舉類型的聲明也可作為成組聲明若干整型符號常量的方法。也就是說,把每個要聲明的符號常量作為一個枚舉值,將各個枚舉值合在一起定義成一個枚舉類型。由于枚舉類型屬于用戶定義數據類型,一旦枚舉類型被定義后就可以使用它來定義變量。 【考點三】 變量
1.變量的定義變量的定義是通過變量聲明語句來實現的,變量聲明語句的一般格式為:[<存儲類>]<類型名><變量名>[=<初值表達式>],...;<存儲類>有四種,它們分別是auto、register、static、extern。<類型名>為已存在的一種數據類型名稱,如char,short,int,long,float,double等基本數據類型名,或者用戶定義的數據類型名。<變量名>是用戶定義的一個標識符,用來表示一個變量,該變量可以通過后面的可選項賦予一個值,稱為給變量賦初值,也叫做對變量進行初始化。C+ +中標識符是區分大小寫的,也就是說,大寫字母和小寫字母被認為是不同的字母。變量名的命名遵循如下規則:(1) 不能是C+ +關鍵字;(2)第一個字符必須是字母或下劃線;(3)中間不能有空格;(4)變量名中不能包括;,′″+-之類的特殊符號。實際上變量名中除了能使用26個英文大小寫字母和數字外,只能使用下劃線"_"。
2.變量的使用方式(1)全局變量和局部變量全局變量是在所有函數定義、類定義和程序塊之外聲明的變量。聲明全局變量時如果在程序中不對它進行專門的初始化,該變量會被系統自動初始化為0。在程序的任何一個函數、類或程序塊之內均可以訪問全局變量。局部變量是在某個函數定義、類定義或程序塊之內聲明的變量。局部變量只能在聲明它的函數、類或程序塊中被訪問。 (2)生存期與作用域生存期是指從一個變量被聲明且分配了內存開始,直到該變量聲明語句失效,它占用的內存空間被釋放為止。一個全局變量的生存期從它被聲明開始,直到程序結束;一個局部變量的生存期從它被聲明開始,直到包含它的最近的一個程序塊結束。作用域是指變量名可以代表該變量存儲空間的使用范圍。一般情況下,變量的作用域與其生存期一致,但由于C+ +語言允許在程序的不同部分為不同變量取同一名字,因此一個變量名的作用域可能小于其生存期。(3)變量的存儲類屬性在C+ +中變量還可以按存儲分配方式的不同被劃分為4種不同的存儲類別,它們分別是:①auto變量:用關鍵字auto聲明的局部變量稱為自動變量。auto為變量聲明時的默認存儲類別,即在變量定義時,如果不顯式標明存儲類別,則系統自動按auto變量處理。auto變量所占用存儲空間的分配和釋放工作將由系統自動完成。②register變量:用關鍵字register聲明的局部變量稱為寄存器變量。register變量可能以寄存器作為其存儲空間。聲明寄存器變量時,關鍵字register的作用只能是建議(而不是強制)系統使用寄存器,原因是寄存器雖然存取速度快,但空間有限,當寄存器不夠用時,該變量仍然按自動變量處理。③static變量:用關鍵字static聲明的變量稱為靜態變量。任何靜態變量的生存期將延續到整個程序的終止。與全局變量一樣,為靜態變量分配的存儲空間在整個程序運行過程中不再被釋放;如果靜態變量未被賦初值,系統將自動為其賦初值為0。④extern變量:用關鍵字extern聲明的變量稱為外部變量。變量一旦被聲明為外部變量,系統就不必像一般變量那樣為其分配內存,因為該變量已在這一局部的外面被定義。外部變量一般用于多個文件組成的程序中,有些變量在多個文件中被聲明,但卻是指同一變量。標明某一變量為外部變量可以避免為其重復分配內存。(4)typedef類型說明使用關鍵字typedef可以為已有類型名定義一個新類型名。其語法格式為:typedef<已有類型名><新類型名>typedef類型說明并沒有真正地定義新的數據類型,它只是相當于給某個已有的數據類型起了一個別名。在規模較大的程序中為了提高代碼可讀性常采用這種形式