c語言中bit的用法
C語言作為一門新型高級(jí)編程語言,在計(jì)算機(jī)軟件編程中具有較為廣泛的應(yīng)用和實(shí)現(xiàn)。下面小編就跟你們?cè)敿?xì)介紹下c語言中bit的用法,希望對(duì)你們有用。
c語言中bit和sbit的區(qū)別
1.bit和sbit都是C51擴(kuò)展的變量類型。
bit和int char之類的差不多,只不過char=8位, bit=1位而已。都是變量,編譯器在編譯過程中分配地址。除非你指定,否則這個(gè)地址是隨機(jī)的。這個(gè)地址是整個(gè)可尋址空間,RAM+FLASH+擴(kuò)展空間。bit只有0和1兩種值,意義有點(diǎn)像Windows下VC中的BOOL。
sbit是對(duì)應(yīng)可位尋址空間的一個(gè)位,可位尋址區(qū):20H~2FH。一旦用了sbi xxx = REGE^6這樣的定義,這個(gè)sbit量就確定地址了。sbit大部分是用在寄存器中的,方便對(duì)寄存器的某位進(jìn)行操作的。
2.bit位標(biāo)量
bit位標(biāo)量是C51編譯器的一種擴(kuò)充數(shù)據(jù)類型,利用它可定義一個(gè)位標(biāo)量,但不能定義位指針,也不能定義位數(shù)組。它的值是一個(gè)二進(jìn)制位,不是0就是1,類似一些高級(jí)語言中的Boolean類型中的True和False。
3.sfr特殊功能寄存器
sfr也是一種擴(kuò)充數(shù)據(jù)類型,點(diǎn)用一個(gè)內(nèi)存單元,值域?yàn)?~255。利用它可以訪問51單片機(jī)內(nèi)部的所有特殊功能寄存器。如用sfr P1 = 0×90這一句定P1為P1端口在片內(nèi)的寄存器,在后面的語句中我們用以用P1 = 255(對(duì)P1端口的所有引腳置高電平)之類的語句來操作特殊功能寄存器。
sfr 關(guān)鍵定后面是一個(gè)要定義的名字,可任意選取,但要符合標(biāo)識(shí)符的命名規(guī)則,名字最好有一定的含義如P1 口可以用P1 為名,這樣程序會(huì)變的好讀好多。等號(hào)后面必須是常數(shù),不允許有帶運(yùn)算符的表達(dá)式,而且該常數(shù)必須在特殊功能寄存器的地址范圍之內(nèi)(80H—FFH),具體可查看附錄中的相關(guān)表。
sfr 是定義8 位的特殊功能寄存器而sfr16 則是用來定義16 位特殊功能寄存器,如8052 的T2 定時(shí)器,可以定義為:
sfr16 T2 = 0xCC; //這里定義8052 定時(shí)器2,地址為T2L=CCH,T2H=CDH用sfr16 定義16 位特殊功能寄存器時(shí),等號(hào)后面是它的低位地址,高位地址一定要位于物理低位地址之上。注意的是不能用于定時(shí)器0 和1 的定義。
sbit可定義可位尋址對(duì)象。如訪問特殊功能寄存器中的某位。其實(shí)這樣應(yīng)用是經(jīng)常要用的如要訪問P1 口中的第2 個(gè)引腳P1。1。我們可以照以下的方法去定義:
(1) sbit 位變量名=位地址
sbit P1_1 = Ox91;這樣是把位的絕對(duì)地址賦給位變量。同sfr 一樣sbit 的位地址必須位于80H—FFH 之間。
。2) sbit 位變量名=特殊功能寄存器名^位位置
sft P1 = 0×90;sbit P1_1 = P1 ^ 1; //先定義一個(gè)特殊功能寄存器名再指定位變量名所在的位置,當(dāng)可尋址位位于特殊功能寄存器中時(shí)可采用這種方法
。3) sbit 位變量名=字節(jié)地址^位位置
sbit P1_1 = 0×90 ^ 1;這種方法其實(shí)和2 是一樣的,只是把特殊功能寄存器的位址直接用常數(shù)表示。 在C51存儲(chǔ)器類型中提供有一個(gè)bdata 的存儲(chǔ)器類型,這個(gè)是指可位尋址的數(shù)據(jù)存儲(chǔ)器,位于單片機(jī)的可位尋址區(qū)中,可以將要求可位錄址的數(shù)據(jù)定義為bdata,如:unsigned char bdata ib; //在可位錄址區(qū)定義ucsigned char 類型的變量ibint bdata ab[2]; //在可位尋址區(qū)定義數(shù)組ab[2],這些也稱為可尋址位對(duì)象sbit ib7=ib^7 //用關(guān)鍵字sbit 定義位變量來獨(dú)立訪問可尋址位對(duì)象的其中一位sbit ab12=ab[1]^12;操作符”^”后面的位位置的最大值取決于指定的基址類型,char0—7,int0—15,long0—31。
sfr 并標(biāo)準(zhǔn)C 語言的關(guān)鍵字,而是Keil 為能直接訪問80C51 中的SFR 而提供了一個(gè)新的關(guān)鍵詞,其用法是:
sfrt 變量名=地址值。
2)符號(hào)P1_0 來表示P1。0 引腳。
在C 語言里,如果直接寫P1。0,C 編譯器并不能識(shí)別,而且P1。0 也不是一個(gè)合法的C語言變量名,所以得給它另起一個(gè)名字,這里起的名為P1_0,可是P1_0 是不是就是P1。0呢?你這么認(rèn)為,C 編譯器可不這么認(rèn)為,所以必須給它們建立聯(lián)系,這里使用了Keil C的關(guān)鍵字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;就是定義用符號(hào)P1_0 來表示P1。0 引腳,如果你愿意也可以起P10 一類的名字,只要下面程序中也隨之更改就行了。
4.sfr16 16位特殊功能寄存器
sfr16占用兩個(gè)內(nèi)存單元,值域?yàn)?~65535。sfr16和sfr一樣用于操作特殊功能寄存器,所不同的是它用于操作占兩個(gè)字節(jié)的寄存器,好定時(shí)器T0和T1。
5.sbit可錄址位
sbit同位是C51中的'一種擴(kuò)充數(shù)據(jù)類型,利用它可以訪問芯片內(nèi)部的RAM中的可尋址位或特殊功能寄存器中的可尋址位。如先前我們定義了sfr P1 = 0×90; //因P1端口的寄存器是可位尋址的,所以我們可以定義sbit P1_1 = P1^1; //P1_1為P1中的P1。1引腳//同樣我們可以用P1。1的地址去寫,如sbit P1_1 = 0×91;這樣我們?cè)谝院蟮某绦蛘Z句中就可以用P1_1來對(duì)P1。1引腳進(jìn)行讀寫操作了。通常這些可以直接使用系統(tǒng)提供的預(yù)處理文件,里面已定義好各特殊功能寄存器的簡(jiǎn)單名字,直接引用可以省去一點(diǎn)時(shí)間,我自己是一直用的。當(dāng)然您也可以自己寫自己的定義文件,用您認(rèn)為好記的名字。
c語言的優(yōu)點(diǎn)介紹
1、簡(jiǎn)潔緊湊、靈活方便
C語言一共只有32個(gè)關(guān)鍵字,9種控制語句,程序書寫形式自由,區(qū)分大小寫。把高級(jí)語言的基本結(jié)構(gòu)和語句與低級(jí)語言的實(shí)用性結(jié)合起來。C 語言可以像匯編語言一樣對(duì)位、字節(jié)和地址進(jìn)行操作,而這三者是計(jì)算機(jī)最基本的工作單元。
2、運(yùn)算符豐富
C語言的運(yùn)算符包含的范圍很廣泛,共有34種運(yùn)算符。C語言把括號(hào)、賦值、強(qiáng)制類型轉(zhuǎn)換等都作為運(yùn)算符處理。從而使C語言的運(yùn)算類型極其豐富,表達(dá)式類型多樣化。靈活使用各種運(yùn)算符可以實(shí)現(xiàn)在其它高級(jí)語言中難以實(shí)現(xiàn)的運(yùn)算。
3、數(shù)據(jù)類型豐富
C語言的數(shù)據(jù)類型有:整型、實(shí)型、字符型、數(shù)組類型、指針類型、結(jié)構(gòu)體類型、共用體類型等。能用來實(shí)現(xiàn)各種復(fù)雜的數(shù)據(jù)結(jié)構(gòu)的運(yùn)算。并引入了指針概念,使程序效率更高。
4、表達(dá)方式靈活實(shí)用
C語言提供多種運(yùn)算符和表達(dá)式值的方法,對(duì)問題的表達(dá)可通過多種途徑獲得,其程序設(shè)計(jì)更主動(dòng)、靈活。它語法限制不太嚴(yán)格,程序設(shè)計(jì)自由度大,如對(duì)整型量與字符型數(shù)據(jù)及邏輯型數(shù)據(jù)可以通用等。
5、允許直接訪問物理地址,對(duì)硬件進(jìn)行操作
由于C語言允許直接訪問物理地址,可以直接對(duì)硬件進(jìn)行操作,因此它既具有高級(jí)語言的功能,又具有低級(jí)語言的許多功能,能夠像匯編語言一樣對(duì)位(bit)、字節(jié)和地址進(jìn)行操作,而這三者是計(jì)算機(jī)最基本的工作單元,可用來寫系統(tǒng)軟件。
6、生成目標(biāo)代碼質(zhì)量高,程序執(zhí)行效率高
C語言描述問題比匯編語言迅速,工作量小、可讀性好,易于調(diào)試、修改和移植,而代碼質(zhì)量與匯編語言相當(dāng)。C語言一般只比匯編程序生成的目標(biāo)代碼效率低10%~20%。
7、可移植性好
C語言在不同機(jī)器上的C編譯程序,86%的代碼是公共的,所以C語言的編譯程序便于移植。在一個(gè)環(huán)境上用C語言編寫的程序,不改動(dòng)或稍加改動(dòng),就可移植到另一個(gè)完全不同的環(huán)境中運(yùn)行。
8、表達(dá)力強(qiáng)
C語言有豐富的數(shù)據(jù)結(jié)構(gòu)和運(yùn)算符。包含了各種數(shù)據(jù)結(jié)構(gòu),如整型、數(shù)組類型、指針類型和聯(lián)合類型等,用來實(shí)現(xiàn)各種數(shù)據(jù)結(jié)構(gòu)的運(yùn)算。C語言的運(yùn)算符有34種,范圍很寬,靈活使用各種運(yùn)算符可以實(shí)現(xiàn)難度極大的運(yùn)算。
C語言能直接訪問硬件的物理地址,能進(jìn)行位(bit)操作。兼有高級(jí)語言和低級(jí)語言的許多優(yōu)點(diǎn)。
它既可用來編寫系統(tǒng)軟件,又可用來開發(fā)應(yīng)用軟件,已成為一種通用程序設(shè)計(jì)語言。
另外C語言具有強(qiáng)大的圖形功能,支持多種顯示器和驅(qū)動(dòng)器。且計(jì)算功能、邏輯判斷功能強(qiáng)大。
【c語言中bit的用法】相關(guān)文章:
C語言中assert用法10-03
C語言中的assert用法10-07
c語言中default的用法10-05
c語言中free的用法10-04
C語言中sscanf的用法09-28
c語言中time函數(shù)的用法10-08
c語言中map的基本用法03-17
c語言中map的用法簡(jiǎn)介10-07