每寫一個程序,總離不開數據的應用,在學習 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,實驗程序如下:
#include <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 引腳進行讀寫操作了。通常這些能 直接使用系統供給的預處理文件,里面已定義好各特殊功能寄存器的簡單名字,直接引 用能省去一點時間,我自己是一直用的。當然您也能自己寫自己的定義文件,用您 認為好記的名字。