<pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

          <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

          <p id="bbfd9"></p>

          <p id="bbfd9"><cite id="bbfd9"></cite></p>

            <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

            <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
            <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
            C語言

            c語言中bit和sbit的區別哪些

            時間:2025-04-21 23:08:30 C語言 我要投稿
            • 相關推薦

            c語言中bit和sbit的區別哪些

              C語言作為一門新型高級編程語言,在計算機軟件編程中具有較為廣泛的應用和實現。下面小編給大家整理了c語言中bit和sbit的區別,供大家參閱。

              c語言中bit和sbit的區別哪些1

              1.bit和sbit都是C51擴展的變量類型。

              bit和int char之類的差不多,只不過char=8位, bit=1位而已。都是變量,編譯器在編譯過程中分配地址。除非你指定,否則這個地址是隨機的。這個地址是整個可尋址空間,RAM+FLASH+擴展空間。bit只有0和1兩種值,意義有點像Windows下VC中的BOOL。

              sbit是對應可位尋址空間的一個位,可位尋址區:20H~2FH。一旦用了sbi xxx = REGE^6這樣的定義,這個sbit量就確定地址了。sbit大部分是用在寄存器中的,方便對寄存器的某位進行操作的。

              2.bit位標量

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

              3.sfr特殊功能寄存器

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

              sfr P1 = 0×90; //定義P1 I/O 口,其地址90H

              sfr 關鍵定后面是一個要定義的名字,可任意選取,但要符合標識符的命名規則,名字最好有一定的含義如P1 口可以用P1 為名,這樣程序會變的好讀好多.等號后面必須是常數,不允許有帶運算符的表達式,而且該常數必須在特殊功能寄存器的地址范圍之內(80H-FFH),具體可查看附錄中的相關表.

              sfr 是定義8 位的特殊功能寄存器而sfr16 則是用來定義16 位特殊功能寄存器,

              如8052 的T2 定時器,可以定義為:

              sfr16 T2 = 0xCC; //這里定義8052 定時器2,地址為T2L=CCH,T2H=CDH

              用sfr16 定義16 位特殊功能寄存器時,等號后面是它的低位地址,高位地址一定要位于物理低位地址之上.注意的是不能用于定時器0 和1 的定義.

              sbit 可定義可位尋址對象.如訪問特殊功能寄存器中的某位.其實這樣應用是經常要用的如要訪問P1 口中的第2 個引腳P1.1.我們可以照以下的方法去定義:

              (1) sbit 位變量名=位地址

              sbit P1_1 = Ox91;

              這樣是把位的絕對地址賦給位變量.同sfr 一樣sbit 的位地址必須位于80H-FFH 之間.

              (2) sbit 位變量名=特殊功能寄存器名位位置

              sft P1 = 0×90;

              sbit P1_1 = P1 ^ 1; //先定義一個特殊功能寄存器名再指定位變量名所在的位置,當可尋址位位于特殊功能寄存器中時可采用這種方法

              (3) sbit 位變量名=字節地址位位置

              sbit P1_1 = 0×90 ^ 1;

              這種方法其實和2 是一樣的,只是把特殊功能寄存器的位址直接用常數表示. 在C51存儲器類型中提供有一個bdata 的存儲器類型,這個是指可位尋址的數據存儲器,位于單片機的可位尋址區中,可以將要求可位錄址的數據定義為bdata,如:

              unsigned char bdata ib; //在可位錄址區定義ucsigned char 類型的變量ib

              int bdata ab[2]; //在可位尋址區定義數組ab[2],這些也稱為可尋址位對象

              sbit ib7=ib^7 //用關鍵字sbit 定義位變量來獨立訪問可尋址位對象的其中一位

              sbit ab12=ab[1]^12;

              操作符”^”后面的位位置的最大值取決于指定的基址類型,char0-7,int0-15,long0-31.sfr 并標準C 語言的關鍵字,而是Keil 為能直接訪問80C51 中的SFR 而提供了一個新的關鍵詞,其用法是:

              sfrt 變量名=地址值。

              2)符號P1_0 來表示P1.0 引腳。

              在C 語言里,如果直接寫P1.0,C 編譯器并不能識別,而且P1.0 也不是一個合法的C語言變量名,所以得給它另起一個名字,這里起的名為P1_0,可是P1_0 是不是就是P1.0呢?你這么認為,C 編譯器可不這么認為,所以必須給它們建立聯系,這里使用了Keil C的關鍵字sbit 來定義,sbit 的用法有三種:

              第一種方法:sbit 位變量名=地址值

              第二種方法:sbit 位變量名=SFR 名稱^變量位地址值

              第三種方法:sbit 位變量名=SFR 地址值^變量位地址值

              如定義PSW 中的OV 可以用以下三種方法:

              sbit OV=0xd2 (1)說明:0xd2 是OV 的位地址值

              sbit OV=PSW^2 (2)說明:其中PSW 必須先用sfr 定義好

              sbit OV=0xD0^2 (3)說明:0xD0 就是PSW 的地址值

              因此這里用sfr P1_0=P1^0;就是定義用符號P1_0 來表示P1.0 引腳,如果你愿意也可以起P10 一類的名字,只要下面程序中也隨之更改就行了。

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

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

              5.sbit可錄址位

              sbit同位是C51中的一種擴充數據類型,利用它可以訪問芯片內部的RAM中的可尋址位或特殊功能寄存器中的可尋址位。如先前我們定義了

              sfr P1 = 0×90; //因P1端口的寄存器是可位尋址的,所以我們可以定義

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

              //同樣我們可以用P1.1的地址去寫,如sbit P1_1 = 0×91;

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

              c語言中bit和sbit的區別哪些2

              bit和sbit這兩者不是C語言里面的,而是C51里面的;

              bit和sbit的區別在于兩者功能不同,具體如下:

              bit是變量類型,相當于boot 只占一個位,最多可定128個bit變量,而sbit是給可位尋址的變量的某一個位定個別名,不另占空間;

              擴展資料:

              bit定義:

              比特是英文 binary digit的縮寫,比特是表示信息的最小單位,是二進制數的一位包含的信息或2個選項中特別指定1個的需要信息量,一般來說,n比特的信息量可以表現出2的n次方種選擇;

              sbit定義:

              sbit是定義特殊功能寄存器的.位變量,bit和sbit都是C51擴展的變量類型,應用如sbit P0_0=P0^0;//即定義P0_0為P0口的第1位,以便進行位操作,bit和int char之類的差不多,只不過char=8位, bit=1位而已,都是變量,編譯器在編譯過程中分配地址;

            【c語言中bit和sbit的區別哪些】相關文章:

            c語言中bit的用法11-01

            C語言中堆和棧的區別有哪些08-12

            C語言中static和extern的區別10-01

            C語言中char*和char[]用法區別09-04

            c語言中單引號和雙引號的區別07-03

            C語言中Sizeof與Strlen的區別與聯系09-02

            C語言中指針與數組的區別10-09

            在C語言中函數調用方式的區別09-01

            C語言中指針與數組的詳解及區別09-07

                    <pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

                    <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

                    <p id="bbfd9"></p>

                    <p id="bbfd9"><cite id="bbfd9"></cite></p>

                      <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

                      <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
                      <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
                      飘沙影院