<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 理解(*(volatile unsigned char *)0x5F

理解(*(volatile unsigned char *)0x5F

作者: 時(shí)間:2016-11-20 來(lái)源:網(wǎng)絡(luò ) 收藏
理解#define SREG (*(volatile unsigned char *)0x5F)

這樣的定義,總是感覺(jué)很奇怪,不知道為什么,今天終于有了一點(diǎn)點(diǎn)心得,請大蝦們多多批磚~~~

本文引用地址:http://dyxdggzs.com/article/201611/318876.htm

嵌入式系統編程,要求程序員能夠利用C語(yǔ)言訪(fǎng)問(wèn)固定的內存地址。既然是個(gè)地址,那么按照C語(yǔ)言的語(yǔ)法規則,這個(gè)表示地址的量應該是指針類(lèi)型。所以,知道要訪(fǎng)問(wèn)的內存地址后,比如0x5F,
第一步是要把它強制轉換為指針類(lèi)型
(unsigned char *)0x5F,AVR的SREG是八位寄存器,所以0x5F強制轉換為指向
unsigned char類(lèi)型。
volatile(可變的)這個(gè)關(guān)鍵字說(shuō)明這變量可能會(huì )被意想不到地改變,這樣編譯器就不會(huì )去假設這個(gè)變量的值了。這種“意想不到地改變”,不是由程序去改變,而是由硬件去改變——意想不到。
第二步,對指針變量解引用,就能操作指針所指向的地址的內容了
*(volatile unsigned char *)0x5F
第三步,小心地把#define宏中的參數用括號括起來(lái),這是一個(gè)很好的習慣,所以#define SREG (*(volatile unsigned char *)0x5F)

類(lèi)似的,如果使用一個(gè)32位處理器,要對一個(gè)32位的內存地址進(jìn)行訪(fǎng)問(wèn),可以這樣定義#define RAM_ADDR (*(volatile unsigned long *)0x0000555F)
然后就可以用C語(yǔ)言對這個(gè)內存地址進(jìn)行讀寫(xiě)操作了
讀:tmp = RAM_ADDR;
寫(xiě):RAM_ADDR = 0x55;

定義未volatile是因為它的值可能會(huì )改變,大家都知道為什么改變了;
如果在一個(gè)循環(huán)操作中需要不停地判斷一個(gè)內存數據,例如要等待SREG的I標志位置位,因為SREG也是映射在SRAM空間,為了加快速度,編譯器可能會(huì )編譯出這樣的代碼:把SREG讀取到Register中,然后不停地判斷Register相應位。而不會(huì )再讀取SREG,這樣當然是不行了,因為程序或其它事件(中斷等)會(huì )改變SREG,結果很可能是一個(gè)死循環(huán)出不來(lái)了。如果定義成volatile型變量,編譯的代碼是這樣的:每次要操作一個(gè)變量的時(shí)候都從內存中讀取一次。
#define SREG (*(volatile unsigned char *)0x5F) 之后,可以進(jìn)行如下基本操作,
unsigned char temp,*ptr;
temp=SREG;把SREG值保存到temp中
SREG=temp;把temp的值賦給SREG
ptr = & SREG; 不知對否,大家試一下。



關(guān)鍵詞: volatileunsignedcha

評論


技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>