<samp id="2irls"><ruby id="2irls"></ruby></samp>
  • <samp id="2irls"><li id="2irls"></li></samp>
      <th id="2irls"><delect id="2irls"></delect></th>

          <th id="2irls"><delect id="2irls"></delect></th>

            (玩電子) 電子技術學習與研究
            當前位置:單片機教程網 >> 基礎教程 >> 瀏覽文章

            第三課 C51數據類型

            作者:佚名   來源:本站原創   點擊數:x  更新時間:2007年07月18日   【字體:

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

            發表評論】【告訴好友】【收藏此文】【關閉窗口

            文章評論

            相關文章

            香港马会全年资枓大全