地址轉(zhuǎn)換-51單片機(jī)C編程
比如,在頭文件reg51.h中,定義了 sfr P0 = 0x80,該地址標(biāo)識的是51芯片的P0端口的8個引腳。(一個字節(jié))。
同時reg51.h中還定義了 sfr SP = 0x81。
如果自己定義 sbit TEST1 = 0x81;實驗時會發(fā)現(xiàn):TEST1實際表示的是0x80標(biāo)識的8bits中的第二個bit位,表示成0x80.1。
按照一般的理解:TEST1應(yīng)該是地址0x81對應(yīng)的8bit的第一個bit位(0x81.0),但是事實不是這樣的;
如果定義 sbit TEST4 = 0x84,表示的是0x80.4;
sbit TEST7 = 0x87,表示的是0x80.7。
但是當(dāng)末尾大于7后,比如 sbit TEST8 = 0x88,表示的是0x88.0, 而不是0x81.0;
sbit TEST9 = 0x89;表示的是0x88.1; 依次類推到0x8f表示0x88.7。
開始是用實驗板上的LED來檢查,后來在uVision里面軟調(diào)試,看Parallel Port0。看Memory是沒用的,特殊功能寄存器的地址和內(nèi)存空間地址是兩個東西;后來看Symbols,終于把sbit定義的控制位的實際地址看清楚,但是沒想明白,為甚么是這樣,規(guī)律是怎樣的。
查了一下資料,原來特殊功能寄存器中不是所有字節(jié)都可進(jìn)行位尋址,支持位尋址字節(jié)地址的是:
0x80,0x88,0x90, 0x98, 0xA0, 0xA0, 0xA8, 0xB0, 0xB8, 0xC0, 0xC8, 0xD0, 0xD8, 0xE0, 0xE8, 0xF0, 0xF8
共16個,這些地址不連是續(xù),能被8整除, 即字節(jié)地址是以8或0為尾數(shù)的。
評論