- 相關推薦
c語言中bit的用法
C語言作為一門新型高級編程語言,在計算機軟件編程中具有較為廣泛的應用和實現。下面小編就跟你們詳細介紹下c語言中bit的用法,希望對你們有用。
c語言中bit和sbit的區別
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 口可以用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 類型的變量ibint 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語言的優點介紹
1、簡潔緊湊、靈活方便
C語言一共只有32個關鍵字,9種控制語句,程序書寫形式自由,區分大小寫。把高級語言的基本結構和語句與低級語言的實用性結合起來。C 語言可以像匯編語言一樣對位、字節和地址進行操作,而這三者是計算機最基本的工作單元。
2、運算符豐富
C語言的運算符包含的范圍很廣泛,共有34種運算符。C語言把括號、賦值、強制類型轉換等都作為運算符處理。從而使C語言的運算類型極其豐富,表達式類型多樣化。靈活使用各種運算符可以實現在其它高級語言中難以實現的運算。
3、數據類型豐富
C語言的數據類型有:整型、實型、字符型、數組類型、指針類型、結構體類型、共用體類型等。能用來實現各種復雜的數據結構的運算。并引入了指針概念,使程序效率更高。
4、表達方式靈活實用
C語言提供多種運算符和表達式值的方法,對問題的表達可通過多種途徑獲得,其程序設計更主動、靈活。它語法限制不太嚴格,程序設計自由度大,如對整型量與字符型數據及邏輯型數據可以通用等。
5、允許直接訪問物理地址,對硬件進行操作
由于C語言允許直接訪問物理地址,可以直接對硬件進行操作,因此它既具有高級語言的功能,又具有低級語言的許多功能,能夠像匯編語言一樣對位(bit)、字節和地址進行操作,而這三者是計算機最基本的工作單元,可用來寫系統軟件。
6、生成目標代碼質量高,程序執行效率高
C語言描述問題比匯編語言迅速,工作量小、可讀性好,易于調試、修改和移植,而代碼質量與匯編語言相當。C語言一般只比匯編程序生成的目標代碼效率低10%~20%。
7、可移植性好
C語言在不同機器上的C編譯程序,86%的代碼是公共的,所以C語言的編譯程序便于移植。在一個環境上用C語言編寫的程序,不改動或稍加改動,就可移植到另一個完全不同的環境中運行。
8、表達力強
C語言有豐富的數據結構和運算符。包含了各種數據結構,如整型、數組類型、指針類型和聯合類型等,用來實現各種數據結構的運算。C語言的運算符有34種,范圍很寬,靈活使用各種運算符可以實現難度極大的運算。
C語言能直接訪問硬件的物理地址,能進行位(bit)操作。兼有高級語言和低級語言的許多優點。
它既可用來編寫系統軟件,又可用來開發應用軟件,已成為一種通用程序設計語言。
另外C語言具有強大的圖形功能,支持多種顯示器和驅動器。且計算功能、邏輯判斷功能強大。
【c語言中bit的用法】相關文章:
C語言中strpbr()函數的用法07-25
c語言中time函數的用法08-27
C語言中volatile的含義08-14
C 語言中宏的使用08-02
C語言中的鏈接編寫05-26
html語言中URL的用法06-20
php語言中session用法07-02
C語言中指針的概念03-16
c語言中邏輯或怎么用07-05
C語言中內存分配問題09-13