新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 單片機c語言教程:C51數據類型

單片機c語言教程:C51數據類型

作者: 時間:2012-09-11 來源:網絡 收藏

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

本文引用地址:http://butianyuan.cn/article/170893.htm

數據類型

長 度

值 域

unsigned char

單字節(jié)

0~255

signed char

單字節(jié)

-128~+127

unsigned int

雙字節(jié)

0~65535

signed int

雙字節(jié)

-32768~+32767

unsigned long

四字節(jié)

0~4294967295

signed long

四字節(jié)

-2147483648~+2147483647

float

四字節(jié)

±1.175494E-38~±3.402823E+38

*

1~3 字節(jié)

對象的地址

bit

0 或 1

sfr

單字節(jié)

0~255

sfr16

雙字節(jié)

0~65535

sbit

0 或 1

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

1. char 字符類型

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

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

2. int 整型

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

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

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

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

#include AT89X51.h> //預處理命令

void main(void) //主函數名

{

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

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

do

{ //do while 組成循環(huán)

for (a=0; a65535; a++)

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

for (a=0; a30000; a++); //空循環(huán)

for (b=0; b255; b++)

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


for (a=0; a30000; a++); //空循環(huán)

}

while(1);

}

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

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

3. long 長整型

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

4. float 浮點型

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

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

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

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 一樣用于操作特殊功能寄存 器,所不一樣的是它用于操作占兩個字節(jié)的寄存器,如定時器 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 引腳進行讀寫操作了。通常這些能 直接使用系統(tǒng)供給的預處理文件,里面已定義好各特殊功能寄存器的簡單名字,直接引 用能省去一點時間,我自己是一直用的。當然您也能自己寫自己的定義文件,用您 認為好記的名字。

c語言相關文章:c語言教程


絕對值編碼器相關文章:絕對值編碼器原理


評論


相關推薦

技術專區(qū)

關閉