位運(yùn)算加速技巧
本方法可以讓C語言指令進(jìn)一步接近匯編指令的執(zhí)行效率,提高單片機(jī)、嵌入式系統(tǒng)的速度和穩(wěn)定性,但編程時應(yīng)采取函數(shù)化的編程法——例如使用swap()函數(shù)時,必要時加注釋。注:本例涉及一些計算機(jī)原理的思想,較為抽象,讀者可利用1和2(01和10)等簡單的數(shù)字進(jìn)行驗證,并上機(jī)實驗,以加深印象。0.位運(yùn)算心法:(掌握粗體字)&(與邏輯):有0出0,全1出1;|(或邏輯):有1出1,全0出0;
~(非邏輯):空即是色,色即是空;
^(異或):相異出1,相同出0;1. 如果乘上一個2的倍數(shù)數(shù)值,可以改用左移運(yùn)算(Left Shift) 加速 300%x = x * 2;x = x * 64;
//改為:
x = x << 1; // 2 == 21x = x << 6; // 64 == 262. 如果除上一個 2 的倍數(shù)數(shù)值,可以改用右移運(yùn)算加速?350%x = x / 2;x = x / 64;
//改為:x = x >> 1; // 2 == 21x = x >> 6; // 64 == 263. 數(shù)值轉(zhuǎn)整數(shù)加速 10%x = int(1.232)
//改為:x = 1.232 >> 0;4. 交換兩個數(shù)值(swap),使用 XOR 可以加速20%var t:int = a;a = b;b = t;
//equals:
a = a^b;b = a^b;a = a^b;5. 正負(fù)號轉(zhuǎn)換,可以加入 300%i = -i;
//改為
i = ~i + 1; // NOT 寫法
//或
i = (i ^ -1) + 1; // XOR 寫法6. 取余數(shù),如果除數(shù)為 2 的倍數(shù),可利用 AND 運(yùn)算加速 600%x = 131 % 4;
//equals:
x = 131 & (4 - 1);7. 利用 AND 運(yùn)算檢查整數(shù)是否為 2 的倍數(shù),可以加速 600%isEven = (i % 2) == 0;//equals:isEven = (i & 1) == 0;8. 加速 Math.abs 600% 的寫法1,寫法2 又比寫法1加速 20%//寫法1i = x < 0 ? -x : x;//寫法2i = (x ^ (x >> 31)) - (x >> 31);//寫法3i=x^(~(x>>31)+1)+(x>>31);9. 比較兩數(shù)值相乘之后是否擁有相同的符號,加速 35%eqSign = a * b > 0;//equals:eqSign = a ^ b > 0;
其它位運(yùn)算技巧
1. RGB 色彩分離var 24bitColor:uint = 0xff00cc;var r:uint = 24bitColor >> 16;var g:uint = 24bitColor >> 8 & 0xFF;var b:uint = 24bitColor & 0xFF;2. RGB 色彩合并var r:uint = 0xff;var g:uint = 0x00;var b:uint = 0xcc;var 24bitColor:uint = r << 16 | g << 8 | b;
-
嵌入式
+關(guān)注
關(guān)注
5089文章
19169瀏覽量
306766 -
位運(yùn)算
+關(guān)注
關(guān)注
0文章
17瀏覽量
8446
原文標(biāo)題:巧用位運(yùn)算,讓嵌入式系統(tǒng)更快更穩(wěn)定!
文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論