程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C51數據類型 詳解

C51數據類型 詳解

編輯:關於C語言
 

每寫一個程序,總離不開數據的應用,在學習 c51 語言的過程中掌握理解數據類型也是很關鍵的。先看表 3-1,表中列出了 KEIL  uVision2  單片機c語言編譯器所支持的數據類型。在標准C語言中基本的數據類型為 char,int,short,long,float 和 double,而在c51編譯器中int 和 short 相同,float 和 double 相同,這裡就不列出說明了。下面來看看它們的具體定 義:

 

數據類型

長    度

值    域

unsigned  char

單字節

0~255

signed  char

單字節

-128~+127

unsigned  int

雙字節

0~65535

signed  int

雙字節

-32768~+32767

unsigned  long

四字節

0~4294967295

signed  long

四字節

-2147483648~+2147483647

float

四字節

±1.175494E-38~±3.402823E+38

*

1~3 字節

對象的地址

bit

0 或 1

sfr

單字節

0~255

sfr16

雙字節

0~65535

sbit

0 或 1

表 3-1    KEIL  uVision2  單片機c語言編譯器所支持的數據類型

1. char 字符類型

char  類型的長度是一個字節,通常用於定義處理字符數據的變量或常量。分無符號字 符類型 unsigned  char 和有符號字符類型 signed  char,默認值為 signed  char 類型。 unsigned  char 類型用字節中所有的位來表示數值,所能表達的數值范圍是 0~255。 signed char 類型用字節中最高位字節表示數據的符號,“0”表示正數,“1”表示負數,負數用補碼表示。所能表示的數值范圍是-128~+127。unsigned char 常用於處理 ASCII 字符或用於處理小於或等於 255 的整型數。

*正數的補碼與原碼相同,負二進制數的補碼等於它的絕對值按位取反後加 1。

2. int 整型

int 整型長度為兩個字節,用於存放一個雙字節數據。分有符號 int 整型數 signed int 和無符號整型數 unsigned int,默認值為 signed int 類型。signed int 表示的數值范圍是-32768~+32767,字節中最高位表示數據的符號,“0”表示正數,“1”表示負數。 unsigned  int 表示的數值范圍是 0~65535。

先停一下來寫個小程序看看 unsigned  char 和 unsigned  int 用於延時的不一樣效果,說明它們的長度是不一樣的,學習它們的使用方法。依舊用上一篇的最小化系統做實驗,不過要加多 一個電阻和 LED,如圖 3-1。實驗中用 D1 的點亮表明正在用 unsigned  int 數值延時,用

D2 點亮表明正在用 unsigned  char 數值延時。


圖 3-1    第 3 課實驗用電路 把這個項目稱為 TwoLED,實驗程序如下:

#i nclude  <AT89X51.h>  //預處理命令

void  main(void)  //主函數名

{

unsigned  int  a;  //定義變量 a 為 unsigned  int 類型

unsigned  char  b;  //定義變量 b 為 unsigned  char 類型

do

{  //do  while 組成循環

for  (a=0;  a<65535;  a++)

P1_0  =  0;  //65535 次設 P1.0 口為低電平,點亮 LED P1_0  =  1;  //設 P1.0 口為高電平,熄滅 LED

for  (a=0;  a<30000;  a++);  //空循環

for  (b=0;  b<255;  b++)

P1_1  =  0;  //255 次設 P1.1 口為低電平,點亮 LED P1_1  =  1;  //設 P1.1 口為高電平,熄滅 LED


for  (a=0;  a<30000;  a++);  //空循環

}

while(1);

}

同樣編譯燒寫,上電運行您就能看到結果了。很明顯 D1 點亮的時間長於 D2 點亮的時間。

這裡必須要講的是,當定義一個變量為特定的數據類型時,在程序使用該變量不應使它的 值 超過數據類型的值域。如本例中的變量 b 不能賦超出 0~255 的值,如 for (b=0; b<255; b++) 改為 for  (b=0;  b<256;  b++),編譯是能通過的,但運行時就會有問題出現,就是說 b 的 值永遠都是小於 256 的,所以無法跳出循環執行下一句 P1_1 = 1,從而造成死循環。同理 a 的值不應超出 0~65535。

3. long 長整型

long 長整型長度為四個字節,用於存放一個四字節數據。分有符號 long 長整型 signed long 和無符號長整型 unsigned  long,默認值為 signed  long 類型。signed  int 表示的數值范圍是-2147483648~+2147483647,字節中最高位表示數據的符號,“0”表示正 數,“1”表示負數。unsigned  long 表示的數值范圍是 0~4294967295。

4. float 浮點型

float 浮點型在十進制中具有 7 位有效數字,是符合 IEEE-754 標准的單精度浮點型數 據,占用四個字節。因浮點數的結構較復雜在以後的章節中再做詳細的討論。

5.*    指針型

指針型本身就是一個變量,在這個變量中存放的指向另一個數據的地址。這個指針變量 要占據一定的內存單元,對不一樣的處理器長度也不盡相同,在 c51 中它的長度一般為 1~

3 個字節。指針變量也具有類型,在以後的課程中有專門一課做探討,這裡就不多說了。

6. bit 位標量

bit 位標量是 c51 編譯器的一種擴充數據類型,利用它可定義一個位標量,但不能定義 位指針,也不能定義位數組。它的值是一個二進制位,不是 0 就是 1,類似一些高級語 言中的 Boolean 類型中的 True 和 False。

7. sfr 特殊功能寄存器

sfr 也是一種擴充數據類型,點用一個內存單元,值域為 0~255。利用它能訪問 51 單片機內部的所有特殊功能寄存器。如用 sfr P1 = 0x90 這一句定 P1 為 P1 端口在片內 的寄存器,在後面的語句中用以用 P1 = 255(對 P1 端口的所有引腳置高電平)之類的 語句來操作特殊功能寄存器。

8.sfr16  16 位特殊功能寄存器

sfr16 占用兩個內存單元,值域為 0~65535。sfr16 和 sfr 一樣用於操作特殊功能寄存 器,所不一樣的是它用於操作占兩個字節的寄存器,如定時器 T0 和 T1。

9. sbit 可錄址位

sbit 同樣是 單片機c語言 中的一種擴充數據類型,利用它能訪問芯片內部的 RAM 中的可尋址


位或特殊功能寄存器中的可尋址位。如先前定義了

sfr  P1  =  0x90;  //因 P1 端口的寄存器是可位尋址的,所以能定義

sbit  P1_1  =  P1^1;    //P1_1 為 P1 中的 P1.1 引腳

// 同樣我們能用 P1.1 的地址去寫,如 sbit  P1_1  =  0x91; 這樣在以後的程序語句中就能用 P1_1 來對 P1.1 引腳進行讀寫操作了。通常這些能 直接使用系統供給的預處理文件,裡面已定義好各特殊功能寄存器的簡單名字,直接引用能省去一點時間,我自己是一直用的。當然您也能自己寫自己的定義文件, 用您 認為好記的名字。

 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved