當(dāng)前位置:首頁 > 單片機 > 單片機
[導(dǎo)讀]位運算應(yīng)用口訣:清零取位要用與,某位置一可用或,若要取反和交換,輕輕松松用異或!移位運算要點1 它們都是雙目運算符,兩個運算分量都是整形,結(jié)果也是整形。2 "<<" 左移:右邊空出的位上補0,左邊的位將從字頭擠掉

位運算應(yīng)用口訣:

清零取位要用與,某位置一可用或,若要取反和交換,輕輕松松用異或!

移位運算要點

1 它們都是雙目運算符,兩個運算分量都是整形,結(jié)果也是整形。

2 "<<" 左移:右邊空出的位上補0,左邊的位將從字頭擠掉,其值相當(dāng)于乘2。

3 ">>"右移:右邊的位被擠掉。對于左邊移出的空位,如果是正數(shù)則空位補0,若為負(fù)數(shù),可能補0或補1,這取決于所用的計算機系統(tǒng)。

4 ">>>"運算符,右邊的位被擠掉,對于左邊移出的空位一概補上0。

位運算符的應(yīng)用 (源操作數(shù)s 掩碼mask)

(1) 按位與-- &

1 清零特定位 (mask中特定位置0,其它位為1,s=s&mask)

2 取某數(shù)中指定位 (mask中特定位置1,其它位為0,s=s&mask)

(2) 按位或-- |

常用來將源操作數(shù)某些位置1,其它位不變。 (mask中特定位置1,其它位為0 s=s|mask)

(3) 位異或-- ^

1 使特定位的值取反 (mask中特定位置1,其它位為0 s=s^mask)

2 不引入第三變量,交換兩個變量的值 (設(shè) a=a1,b=b1)

目標(biāo) 操作 操作后狀態(tài)

a=a1^b1 a=a^b a=a1^b1,b=b

b=a1^b1^b1 b=a^b a=a1^b1,b=a

a=b1^a1^a1 a=a^b a=b1,b=a

二進(jìn)制補碼運算公式:

-x = ~x + 1 = ~(x-1)

~x = -x-

-(~x) = x+

~(-x) = x-

x+y = x - ~y - 1 = (x|y)+(x&y)

x-y = x + ~y + 1 = (x|~y)-(~x&y)

x^y = (x|y)-(x&y)

x|y = (x&~y)+y

x&y = (~x|y)-~x

x==y: ~(x-y|y-x)

x!=y: x-y|y-x

x< y: (x-y)^((x^y)&((x-y)^x))

x<=y: (x|~y)&((x^y)|~(y-x))

x< y: (~x&y)|((~x|y)&(x-y))//無符號x,y比較

x<=y: (~x|y)&((x^y)|~(y-x))//無符號x,y比較

應(yīng)用舉例

(1) 判斷int型變量a是奇數(shù)還是偶數(shù)

a&1 = 0 偶數(shù)

a&1 = 1 奇數(shù)

(2) 取int型變量a的第k位 (k=0,1,2……sizeof(int)),即a>>k&

(3) 將int型變量a的第k位清0,即a=a&~(1<

(4) 將int型變量a的第k位置1, 即a=a|(1<

(5) int型變量循環(huán)左移k次,即a=a<

(6) int型變量a循環(huán)右移k次,即a=a>>k|a<<16-k (設(shè)sizeof(int)=16)

(7)整數(shù)的平均值

對于兩個整數(shù)x,y,如果用 (x+y)/2 求平均值,會產(chǎn)生溢出,因為 x+y 可能會大于INT_MAX,但是我們知道它們的平均值是肯定不會溢出的,我們用如下算法:

int average(int x, int y) //返回X,Y 的平均值

{

return (x&y)+((x^y)>>1);

}

(8)判斷一個整數(shù)是不是2的冪,對于一個數(shù) x >= 0,判斷他是不是2的冪

boolean power2(int x)

{

return ((x&(x-1))==0)&&(x!=0);

}

(9)不用temp交換兩個整數(shù)

void swap(int x , int y)

{

x ^= y;

y ^= x;

x ^= y;

}

(10)計算絕對值

int abs( int x )

{

int y ;

y = x >> 31 ;

return (x^y)-y ; //or: (x+y)^y

}

(11)取模運算轉(zhuǎn)化成位運算 (在不產(chǎn)生溢出的情況下):a % (2^n) 等價于 a & (2^n - 1)

(12)乘法運算轉(zhuǎn)化成位運算 (在不產(chǎn)生溢出的情況下):a * (2^n) 等價于 a<< n

(13)除法運算轉(zhuǎn)化成位運算 (在不產(chǎn)生溢出的情況下):a / (2^n) 等價于 a>> n

例: 12/8 == 12>>3

(14) a % 2 等價于 a & 1

(15) if (x == a) x= b;

else x= a;

等價于 x= a ^ b ^ x;

(16) x 的 相反數(shù)表示為 (~x+1)

(17) 實現(xiàn)最低n位為1,其余位為0的位串信息:~(~0 << n)

(18)截取變量x自p位開始的右邊n位的信息:(x >> (1+p-n)) & ~(~0 << n)

(19)截取old變量第row位,并將該位信息裝配到變量new的第15-k位:new |= ((old >> row) & 1) << (15 – k)

(20)設(shè)s不等于全0,代碼尋找最右邊為1的位的序號j:

for(j = 0; ((1 << j) & s) == 0; j++) ;

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉