熱門(mén): 51單片機(jī) | 24小時(shí)必答區(qū) | 單片機(jī)教程 | 單片機(jī)DIY制作 | STM32 | Cortex M3 | 模數(shù)電子 | 電子DIY制作 | 音響/功放 | 拆機(jī)樂(lè)園 | Arduino | 嵌入式OS | 程序設(shè)計(jì)
![]() |
發(fā)布時(shí)間: 2022-12-1 08:22
正文摘要:((BYTE *)&w)[0] 是取W是首地址強(qiáng)制轉(zhuǎn)換指針類(lèi)型,后面的又跟著[]是什么意思? 如果是指針數(shù)組的話 取值應(yīng)該寫(xiě)成 *((BYTE *)&w)[0] 圖中代碼交換的指針地址還是值 |
交換的是值。w的高8位值放在ret的低8位,w的低8位值放在ret的高8位。所以這個(gè)函數(shù)就是交換w的高低8位 |
交換的是值, |
cnos 發(fā)表于 2022-12-2 20:46 直接調(diào)用匯編指令不是更好嗎 |
顯然交換的是值,但是在51上面這么用很危險(xiǎn),因?yàn)榫植孔兞慷际庆o態(tài)分配的,而不是標(biāo)準(zhǔn)c語(yǔ)言那樣在堆棧上生成局部變量,調(diào)用這個(gè)函數(shù)的函數(shù)應(yīng)該在這個(gè)函數(shù)返回后,把返回值保存起來(lái),不然很容易被覆蓋。 |
這種寫(xiě)法的目的是為了讓編譯直接編譯出MOV direct 的匯編指令,追求代碼效率才這樣寫(xiě)。其他寫(xiě)法都不會(huì)編譯出直接MOV指令。我以前用AT89C的時(shí)候單片機(jī)速度有限,也是這么干的。要不然忙不過(guò)來(lái),一個(gè)頻繁中斷的函數(shù)。 |
BYTE是一個(gè)字節(jié),那么就是把一個(gè)數(shù)的bit0~bit7與bit8~bit15進(jìn)行交換。 ((BYTE *)&w)[0]的運(yùn)算過(guò)程如下: 1、&w取變量w的地址,其實(shí)是等到的一個(gè)指針; 2、((BYTE *)&w)把得到的指針,強(qiáng)制轉(zhuǎn)換成BYTE *(指向BYTE的指針); 3、((BYTE *)&w)[0]獲取指針指向地址中的內(nèi)容(w的bit0~bit7),注意指針也可以進(jìn)行下標(biāo)運(yùn)算。 其實(shí)這樣寫(xiě)你就很容易看明白了: WORD ret; BYTE * p1 = (BYTE *)&w; BYTE * p2 = (BYTE *)&ret; *(p2 + 1) = *p1; *p2 = *(p1 + 1); return ret; |
[]中的數(shù)代表下標(biāo)地址,所以((BYTE *)&w)[0]代表取下標(biāo)0位置的值,前面不用加*號(hào)。 |
交換的是地址。前面加*號(hào)交換的就是值了。 |
關(guān)注下這個(gè)燒腦的問(wèn)題![]() |
Powered by 單片機(jī)教程網(wǎng)