<address id="ousso"></address>
<form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
  1. 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

    <address id="ousso"></address>
    <form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
    1. 日日做夜狠狠爱欧美黑人