C語言的數據類型介紹_第1頁
C語言的數據類型介紹_第2頁
C語言的數據類型介紹_第3頁
C語言的數據類型介紹_第4頁
C語言的數據類型介紹_第5頁
已閱讀5頁,還剩22頁未讀 繼續免費閱讀

下載本文檔

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

文檔簡介

本文格式為Word版,下載可任意編輯——C語言的數據類型介紹導語:所謂數據類型是按被說明量的性質,表示形式,占據存儲空間的多少,構造特點來劃分的。在C語言中,數據類型可分為:根本數據類型,構造數據類型,指針類型,空類型四大類。以下是我為大家用心整理的C語言的數據類型介紹,接待大家參考!

1.根本數據類型

根本數據類型最主要的特點是,其值不成以再分解為其它類型。也就是說,根本數據類型是自我說明的。

2.構造數據類型構造數據類型

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

·數組類型

·布局類型

·聯合類型

3.指針類型

指針是一種特殊的,同時又是具有重要作用的數據類型。其值用來表示某個量在內存儲器中的地址。雖然指針變量的取值類似于整型量,但這是兩個類型完全不同的量,因此不能混為一談。4.空類型在調用函數值時,通常應向調用者返回一個函數值。這個返回的函數值是具有確定的數據類型的,應在函數定義及函數說明中給以說明,例如在例題中給出的max函數定義中,函數頭為:intmaxinta,intb;其中“int”類型說明符即表示該函數的返回值為整型量。又如在例題中,使用了庫函數sin,由于系統規定其函數返回值為雙精度浮點型,因此在賦值語句s=sinx;中,s也務必是雙精度浮點型,以便與sin函數的返回值一致。所以在說明片面,把s說明為雙精度浮點型。但是,也有一類函數,調用后并不需要向調用者返回函數值,這種函數可以定義為“空類型”。其類型說明符為void。在第五章函數中還要細致介紹。在本章中,我們先介紹根本數據類型中的整型、浮點型和字符型。其余類型在以后各章中不斷介紹。

對于根本數據類型量,按其取值是否可變更又分為常量和變量兩種。在程序執行過程中,其值不發生變更的量稱為常量,取值可變的量稱為變量。它們可與數據類型結合起來分類。例如,可分為整型常量、整型變量、浮點常量、浮點變量、字符常量、字符變量、枚舉常量、枚舉變量。在程序中,常量是可以不經說明而直接引用的,而變量那么務必先說明后使用。

整型量

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

整型常量

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

以下各數是合法的八進制數:

015十進制為130101十進制為650177777十進制為65535

以下各數不是合法的八進制數:

256無前綴003A2包含了非八進制數碼-0127展現了負號

2.十六進制整常數

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

以下各數是合法的十六進制整常數:

0X2A十進制為420XA0十進制為1600XFFFF十進制為65535

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

5A無前綴0X0X3H含有非十六進制數碼

3.十進制整常數

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

以下各數是合法的十進制整常數:

237-568655351627

以下各數不是合法的十進制整常數:

023不能有前導023D含有非十進制數碼

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

十進制長整常數158L十進制為158358000L十進制為-358000

八進制長整常數012L十進制為10077L十進制為630200000L十進制為65536

十六進制長整常數0X15L十進制為210XA5L十進制為1650X10000L十進制為65536

長整數158L和根本整常數158在數值上并無識別。但對158L,由于是長整型量,C編譯系統將為它調配4個字節存儲空間。而對158,由于是根本整型,只調配2個字節的存儲空間。因此在運算和輸出格式上要予以留神,制止出錯。無符號數也可用后綴表示,整型常數的無符號數的后綴為“U”或“u”。例如:358u,0x38Au,235Lu均為無符號數。前綴,后綴可同時使用以表示各種類型的數。如0XA5Lu表示十六進制無符號長整數A5,其十進制為165。

整型變量

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

1.根本型

類型說明符為int,在內存中占2個字節,其取值為根本整常數。

2.短整量

類型說明符為shortint或shortC110F1。所占字節和取值范圍均與根本型一致。

3.長整型

類型說明符為longint或long,在內存中占4個字節,其取值為長整常數。

4.無符號型

類型說明符為unsigned。

無符號型又可與上述三種類型匹配而構成:

1無符號根本型類型說明符為unsignedint或unsigned。

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

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

各種無符號類型量所占的內存空間字節數與相應的有符號類型量一致。但由于省去了符號位,故不能表示負數。下表列出了TurboC中各類整型量所調配的內存字節數及數的表示范圍。

類型說明符數的范圍調配字節數

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為無符號整型變量

在書寫變量說明時,應留神以下幾點:

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

2.結果一個變量名之后務必以“;”號結尾。

3.變量說明務必放在變量使用之前。一般放在函數體的開頭片面。

[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;

printfc=x+a=%d,d=y+b=%d,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

顯示程序運行結果oflongx,y;

inta,b,c,d;

c=x+a;

d=y+b;

從程序中可以看到:x,y是長整型變量,a,b是根本整型變量。它們之間允許舉行運算,運算結果為長整型。但c,d被定義為根本整型,因此結果結果為根本整型。本例說明,不同類型的量可以參與運算并相互賦值。其中的類型轉換是由編譯系統自動完成的。有關類型轉換的規矩將在以后介紹。

實型量

實型常量

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

1.十進制數形式

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

2.指數形式

由十進制數,加階碼標志“e”或“E”以及階碼只能為整數,可以帶符號組成。其一般形式為aEna為十進制數,n為十進制整數其值為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*以下不是合法的實數345無小數點E7階碼標志E之前多數字-5無階碼標志53.-E3負號位置不對2.7E無階碼

標準C允許浮點數使用后綴。后綴為“f”或“F”即表示該數為浮點數。如356f和356.是等價的。例2.2說領略這種處境:

voidmain

printf%f%f,356.,356f;

void指明main不返回任何值利用printf顯示結果終止

實型變量

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

其類型說明符為float單精度說明符,double雙精度說明符。在TurboC中單精度型占4個字節32位內存空間,其數值范圍為3.4E-38~3.4E+38,只能供給七位有效數字。雙精度型占8個字節64位內存空間,其數值范圍為1.7E-308~1.7E+308,可供給16位有效數字。

實型變量說明的格式和書寫規矩與整型一致。

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

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

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

voidmain

floata;

doubleb;

a=33333.33333;

b=33333.33333333333333;

printf%f%f,a,b;

此程序說明float、double的不同

a■■■■

b■■■■■■■■

a33333.33333

b33333.33333333333;;

顯示程序結果

此程序說明float、double的不同

floata;

doubleb;

a=33333.33333;

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

[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.字符可以是字符集中任意字符。但數字被定義為字符型之后就

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

轉義字符

轉義字符是一種特殊的字符常量。轉義字符以反斜?quot;開頭,后跟一個或幾個字符。轉義字符具有特定的含義,不同于字符原有的意義,故稱“轉義”字符。例如,在前面各例題printf函數的格式串中用到的“”就是一個轉義字符,其意義是“回車換行”。轉義字符主要用來表示那些用一般字符不便于表示的操縱代碼。

常用的轉義字符及其含義

轉義字符轉義字符的意義

回車換行

橫向跳到下一制表位置

v豎向跳格

退格

回車

f走紙換頁

反斜線符

單引號符

a鳴鈴

ddd1~3位八進制數所代表的字符

xhh1~2位十六進制數所代表的字符

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

voidmain

inta,b,c;

a=5;b=6;c=7;

printf%d%d%d%d%d%d,a,b,c,a,b,c;

此程序練習轉義字符的使用

a、b、c為整數5-a,6-b,7-c

調用printf顯示程序運行結果

printf%d%d%d%d%d%d,a,b,c,a,b,c;

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

字符變量

字符變量的取值是字符常量,即單個字符。字符變量的類型說明符是char。字符變量類型說明的格式和書寫規矩都與整型變量一致。

例如:

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

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

b01111001

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

main

chara,b;

a=120;

b=121;

printf%c,%c%d,%d,a,b,a,b;

a■b■

a--120

b121

顯示程序結果chara,b;

a=120;

b=121;

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

voidmain

chara,b;

a=x;

b=y;

a=a-32;

b=b-32;

printf%c,%c%d,%d,a,b,a,b;

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

把小寫字母換成大寫字母

以整型和字符型輸出

本例中,a,b被說明為字符變量并賦予字符值,C語言允許字符變量參與數值運算,即用字符的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等都是合法的字符串常量。字符串常量和字符常量是不同的量。它們之間主要有以下識別:

1.字符常量由單引號括起來,字符串常量由雙引號括起來。

2.字符常量只能是單個字符,字符串常量那么可以含一個或多個字符。

3.可以把一個字符常量賦予一個字符變量,但不能把一個字符串常量賦予一個字符變量。在C語言中沒有相應的字符串變量。

這是與BASIC語言不同的。但是可以用一個字符數組來存放一個字符串常量。在數組一章內予以介紹。

4.字符常量占一個字節的內存空間。字符串常量占的內存字節數等于字符串中字節數加1。增加的一個字節中存放字符ASCII碼為0。這是字符串終止的標志。例如,字符串Cprogram在內存中所占的字節為:Cprogram。字符常量a和字符串常量a雖然都只有一個字符,但在內存中的處境是不同的。

a在內存中占一個字節,可表示為:a

a在內存中占二個字節,可表示為:a符號常量

符號常量

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

#define標識符常量

其中#define也是一條預處理命令預處理命令都?quot;#開頭,稱為宏定義命令在第九章預處理程序中將進一步介紹,其功能是把該標識符定義為其后的常量值。一經定義,以后在程序中全體展現該標識符的地方均代之以該常量值。習慣上符號常量的標識符用大寫字母,變量標識符用小寫字母,以示識別。

#definePI3.14159

voidmain

floats,r;

r=5;

s=PI*r*r;

printfs=%f,s;

由宏定義命令定義PI為3.14159s,r定義為實數5-rPI*r*r-s

顯示程序結果floats,r;r=5;s=PI*r*r;本程序在主函數之前由宏定義命令定義PI為3.14159,在程序中即以該值代替PI。s=PI*r*r等效于s=3.14159*r*r。理應留神的是,符號常量不是變量,它所代表的值在整個作用域內不能再變更。也就是說,在程序中,不能再用賦值語句對它重新賦值。

變量的初值和類型轉換

變量賦初值

在程序中往往需要對變量賦初值,以便使用變量。語言程序中可有多種方法,在定義時賦以初值的方法,這種方法稱為初始化。在變量說明中賦初值的一般形式為:

類型說明符變量1=值1,變量2=值2,……;例如:

inta=b=c=5;

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

charch1=K,ch2=P;

應留神,在說明中不允許連續賦值,如a=b=c=5是不合法的。

voidmain

inta=3,b,c=5;

b=a+c;

printfa=%d,b=%d,c=%d,a,b,c;

a3,b--0,c5

b--a+c

顯示程序運行結果

變量類型的轉換

變量的數據類型是可以轉換的。轉換的方法有兩種,一種是自動轉換,一種是強制轉換。

自動轉換

自動轉

溫馨提示

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

最新文檔

評論

0/150

提交評論