C語言它是把高階語言的基本結構和語句與低階語言的實用性結合起來的工作單元。下面就來和小編一起看看C語言的資料型別吧。
C語言的資料型別
1.基本資料型別
基本資料型別最主要的特點是,其值不可以再分解為其它型別。也就是說,基本資料型別是自我說明的。
2.構造資料型別構造資料型別
是根據已定義的一個或多個數據型別用構造的方法來定義的。也就是說,一個構造型別的值可以分解成若干個“成員”或“元素”。每個“成員”都是一個基本資料型別或又是一個構造型別。在C語言中,構造型別有以下幾種:
·陣列型別
·結構型別
·聯合型別
3.指標型別
指標是一種特殊的,同時又是具有重要作用的資料型別。其值用來表示某個量在記憶體儲器中的地址。雖然指標變數的取值類似於整型量,但這是兩個型別完全不同的量,因此不能混為一談。4.空型別在呼叫函式值時,通常應向呼叫者返回一個函式值。這個返回的函式值是具有一定的資料型別的,應在函式定義及函式說明中給以說明,例如在例題中給出的max函式定義中,函式頭為: int max(int a,int b);其中“int ”型別說明符即表示該函式的返回值為整型量。又如在例題中,使用了庫函式 sin,由於系統規定其函式返回值為雙精度浮點型,因此在賦值語句s=sin (x);中,s 也必須是雙精度浮點型,以便與sin函式的返回值一致。所以在說明部分,把s說明為雙精度浮點型。但是,也有一類函式,呼叫後並不需要向呼叫者返回函式值, 這種函式可以定義為“空型別”。其型別說明符為void。在第五章函式中還要詳細介紹。在本章中,我們先介紹基本資料型別中的整型、浮點型和字元型。其餘型別在以後各章中陸續介紹。
對於基本資料型別量,按其取值是否可改變又分為常量和變數兩種。在程式執行過程中,其值不發生改變的量稱為常量,取值可變的量稱為變數。它們可與資料型別結合起來分類。例如,可分為整型常量、整型變數、浮點常量、浮點變數、字元常量、字元變數、列舉常量、列舉變數。在程式中,常量是可以不經說明而直接引用的,而變數則必須先說明後使用。
整型量
整型量包括整型常量、整型變數。整型常量就是整常數。在C語言中,使用的整常數有八進位制、十六進位制和十進位制三種。
整型常量
1.八進位制整常數八進位制整常數必須以0開頭,即以0作為八進位制數的字首。數碼取值為0~7。八進位制數通常是無符號數。
以下各數是合法的八進位制數:
015(十進位制為13) 0101(十進位制為65) 0177777(十進位制為65535)
以下各數不是合法的八進位制數:
256(無字首0) 03A2(包含了非八進位制數碼) -0127(出現了負號)
2.十六進位制整常數
十六進位制整常數的字首為0X或0x。其數碼取值為0~9,A~F或a~f。
以下各數是合法的十六進位制整常數:
0X2A(十進位制為42) 0XA0 (十進位制為160) 0XFFFF (十進位制為65535)
以下各數不是合法的十六進位制整常數:
5A (無字首0X) 0X3H (含有非十六進位制數碼)
3.十進位制整常數
十進位制整常數沒有字首。其數碼為0~9。
以下各數是合法的十進位制整常數:
237 -568 65535 1627
以下各數不是合法的十進位制整常數:
023 (不能有前導0) 23D (含有非十進位制數碼)
在程式中是根據字首來區分各種進位制數的。因此在書寫常數時不要把字首弄錯造成結果不正確。4.整型常數的字尾在16位字長的機器上,基本整型的長度也為16位,因此表示的數的範圍也是有限定的。十進位制無符號整常數的範圍為0~65535,有符號數為-32768~+32767。八進位制無符號數的表示範圍為0~0177777。十六進位制無符號數的表示範圍為0X0~0XFFFF或0x0~0xFFFF。如果使用的數超過了上述範圍,就必須用長整型數來表示。長整型數是用字尾“L”或“l”來表示的。例如:
十進位制長整常數 158L (十進位制為158) 358000L (十進位制為-358000)
八進位制長整常數 012L (十進位制為10) 077L (十進位制為63) 0200000L (十進位制為65536)
十六進位制長整常數 0X15L (十進位制為21) 0XA5L (十進位制為165) 0X10000L (十進位制為65536)
長整數158L和基本整常數158 在數值上並無區別。但對158L,因為是長整型量,C編譯系統將為它分配4個位元組儲存空間。而對158,因為是基本整型,只分配2 個位元組的儲存空間。因此在運算和輸出格式上要予以注意,避免出錯。無符號數也可用字尾表示,整型常數的無符號數的字尾為“U”或“u”。例如: 358u,0x38Au,235Lu 均為無符號數。字首,字尾可同時使用以表示各種型別的數。如0XA5Lu表示十六進位制無符號長整數A5,其十進位制為165。
整型變數
整型變數可分為以下幾類:
1.基本型
型別說明符為int,在記憶體中佔2個位元組,其取值為基本整常數。
2.短整量
型別說明符為short int或short'C110F1。所佔位元組和取值範圍均與基本型相同。
3.長整型
型別說明符為long int或long ,在記憶體中佔4個位元組,其取值為長整常數。
4.無符號型
型別說明符為unsigned。
無符號型又可與上述三種類型匹配而構成:
(1)無符號基本型 型別說明符為unsigned int或unsigned。
(2)無符號短整型 型別說明符為unsigned short
(3)無符號長整型 型別說明符為unsigned long
各種無符號型別量所佔的記憶體空間位元組數與相應的有符號型別量相同。但由於省去了符號位,故不能表示負數。 下表列出了Turbo C中各類整型量所分配的記憶體位元組數及數的表示範圍。
型別說明符 數的範圍 分配位元組數
int -32768~32767 ■■
short int -32768~32767 ■■
signed int -32768~32767 ■■
unsigned int 0~65535 ■■
long int -2147483648~2147483647 ■■■■
unsigned long 0~4294967295 ■■■■
整型變數的說明
變數說明的一般形式為: 型別說明符 變數名識別符號,變數名識別符號,...; 例如:
int a,b,c; (a,b,c為整型變數)
long x,y; (x,y為長整型變數)
unsigned p,q; (p,q為無符號整型變數)
在書寫變數說明時,應注意以下幾點:
1.允許在一個型別說明符後,說明多個相同型別的變數。各變數名之間用逗號間隔。型別說明符與變數名之間至少用一個空格間隔。
2.最後一個變數名之後必須以“;”號結尾。
3.變數說明必須放在變數使用之前。一般放在函式體的開頭部分。
[Practice] //1int a,b;
short int c;
short d=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
of Vtable
'Vupdate
1,0;2,0
3,0
4,100
1,80
2,180
3,360
4,200
of Vupdate
of Practice
[Practice] //2int a=5;
int b=9;
long int c;
long d;
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
of Vtable
'Vupdate
1,5
2,9
3,0
4,0
3,7
4,315
3,31255875
1,-5112
of Vupdate
of Practice
[Practice] //3int a=6,b=19;
unsigned int c;
int d;
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
of Vtable
'Vupdate
1,6;2,19
3,0
4,0
3,65530
4,-114
1,-101
2,101
of Vupdate
of Practice
void main(){
long x,y;
int a,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",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
顯示程式執行結果 of long x,y;
int a,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”以及階碼(只能為整數,可以帶符號)組成。其一般形式為a E n (a為十進位制數,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說明了這種情況:
void main()
{
printf("%f%f",356.,356f);
}void 指明main不返回任何值 利用printf顯示結果 結束
實型變數
實型變數分為兩類:單精度型和雙精度型,
其型別說明符為float 單精度說明符,double 雙精度說明符。在Turbo C中單精度型佔4個位元組(32位)記憶體空間,其數值範圍為3.4E-38~3.4E+38,只能提供七位有效數字。雙精度型佔8 個位元組(64位)記憶體空間,其數值範圍為1.7E-308~1.7E+308,可提供16位有效數字。
實型變數說明的格式和書寫規則與整型相同。
例如: float x,y; (x,y為單精度實型量)
double a,b,c; (a,b,c為雙精度實型量)
實型常數不分單、雙精度,都按雙精度double型處理。
void main()
{
float a;
double b;
a=33333.33333;
b=33333.33333333333333;
printf("%f%f",a,b);
}此程式說明float、double的不同
a ■■■■
b ■■■■■■■■
a<---33333.33333
b<---33333.33333333333;;
顯示程式結果
此程式說明float、double的不同
float a;
double b;
a=33333.33333;
b=33333.33333333333333; 從本例可以看出,由於a 是單精度浮點型,有效位數只有七位。而整數已佔五位,故小數二位後之後均為無效數字。b 是雙精度型,有效位為十六位。但Turbo C 規定小數後最多保留六位,其餘部分四捨五入。
[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
字元型量
字元型量包括字元常量和字元變數。
字元常量
字元常量是用單引號括起來的一個字元。例如'a','b','=','+','?'都是合法字元常量。在C語言中,字元常量有以下特點:
1.字元常量只能用單引號括起來,不能用雙引號或其它括號。
2.字元常量只能是單個字元,不能是字串。
3.字元可以是字符集中任意字元。但數字被定義為字元型之後就
不能參與數值運算。如'5'和5 是不同的。'5'是字元常量,不能參與運算。
轉義字元
轉義字元是一種特殊的字元常量。轉義字元以反斜線""開頭,後跟一個或幾個字元。轉義字元具有特定的含義,不同於字元原有的意義,故稱“轉義”字元。例如,在前面各例題printf函式的格式串中用到的“”就是一個轉義字元,其意義是“回車換行”。轉義字元主要用來表示那些用一般字元不便於表示的控制程式碼。
常用的轉義字元及其含義
轉義字元 轉義字元的意義
回車換行
橫向跳到下一製表位置
v 豎向跳格
退格
回車
f 走紙換頁
反斜線符""
' 單引號符
a 鳴鈴
ddd 1~3位八進位制數所代表的字元
xhh 1~2位十六進位制數所代表的字元
廣義地講,C語言字符集中的任何一個字元均可用轉義字元來表示。表2.2中的ddd和xhh正是為此而提出的。ddd和hh分別為八進位制和十六進位制的ASCII程式碼。如101表示字?quot;A" ,102表示字母"B",134表示反斜線,XOA表示換行等。轉義字元的使用
void main()
{
int a,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。字元變數型別說明的格式和書寫規則都與整型變數相同。
例如:
char a,b; 每個字元變數被分配一個位元組的`記憶體空間,因此只能存放一個字元。字元值是以ASCII碼的形式存放在變數的記憶體單元之中的。如x的
十進位制ASCII碼是120,y的十進位制ASCII碼是121。對字元變數a,b賦予'x'和'y'值: a='x';b='y';實際上是在a,b兩個單元記憶體放120和121的二進位制程式碼: a 0 1 1 1 1 0 0 0
b 0 1 1 1 1 0 0 1
所以也可以把它們看成是整型量。 C語言允許對整型變數賦以字元值,也允許對字元變數賦以整型值。在輸出時, 允許把字元變數按整型量輸出,也允許把整型量按字元量輸出。 整型量為二位元組量,字元量為單位元組量,當整型量按字元型量處理時, 只有低八位位元組參與處理。
main()
{
char a,b;
a=120;
b=121;
printf("%c,%c%d,%d",a,b,a,b);
}
a ■ b ■
a <-- 120
b <--- 121
顯示程式結果
本程式中說明a,b為字元型,但在賦值語句中賦以整型值。從結果看,a,b值的輸出形式取決於printf函式格式串中的格式符,當格式符為"c"時,對應輸出的變數值為字元,當格式符為"d"時,對應輸出的變數值為整數。
void main()
{
char a,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] //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" 等都是合法的字串常量。字串常量和字元常量是不同的量。它們之間主要有以下區別:
1.字元常量由單引號括起來,字串常量由雙引號括起來。
2.字元常量只能是單個字元,字串常量則可以含一個或多個字元。
3.可以把一個字元常量賦予一個字元變數,但不能把一個字串常量賦予一個字元變數。在C語言中沒有相應的字串變數。
這是與BASIC 語言不同的。但是可以用一個字元陣列來存放一個字串常量。在陣列一章內予以介紹。
4.字元常量佔一個位元組的記憶體空間。字串常量佔的記憶體位元組數等於字串中位元組數加1。增加的一個位元組中存放字元"