標題: 一個位運算頭文件 [打印本頁]

作者: himanzj    時間: 2022-9-22 21:48
標題: 一個位運算頭文件
一個位運算頭文件,操作第幾位,可以使用變量

BIT.H
  1. char bits[9]= {0,1,2,4,8,16,32,64,128};

  2. //v,需要設置的字節(jié),
  3. //b,要設置第幾位,從 第1 位開始
  4. #define BIT_SET(v,b) (v)|=bits[b]
  5. #define BIT_CLR(v,b) (v)&= ~bits[b]
  6. #define BIT_GET(v,b) (v)& bits[b]

  7. //ex.
  8. //char c=6,t;
  9. //BIT_SET(c,6); // c 的第6 位設置 1
  10. //BIT_CLR(c,2); //c 的第2位 清 0
  11. //t= BIT_GET(c,2);  讀取c的 第2 位//
復制代碼

作者: himanzj    時間: 2022-9-22 21:50
好用,歡迎使用
作者: himanzj    時間: 2022-9-28 08:57
增加一個 某位取反運算

#define BIT_REV(v,b) v^= bits[b]  //把v 的 b位取反

作者: 188610329    時間: 2022-9-28 09:42
宏指令頭文件 不能這么寫的……
宏指令的目的是: 在不影響運行效率的前提下, 使指令的易讀性提高。
前提是不影響運行效率。這一點非常重要。

#define BIT_SET(v,b) (v)|= 0x01<<(b)
#define BIT_CLR(v,b) (v)&= ~(0x01<<(b))
#define BIT_GET(v,b) (v)& (0x01<<(b))

把這3個和你寫的3個編譯后 用實例對照看看, 比較一下代碼大小,和執(zhí)行速度的區(qū)別。
作者: himanzj    時間: 2022-9-29 07:25
188610329 發(fā)表于 2022-9-28 09:42
宏指令頭文件 不能這么寫的……
宏指令的目的是: 在不影響運行效率的前提下, 使指令的易讀性提高。
前 ...

左移運算效率高 還是 直接取數(shù) 效率高
作者: hhh402    時間: 2022-9-29 09:32
99%的單片機應用不需要考慮效率,在大量使用延時函數(shù)的時代談效率可笑,對于編程來說熟悉什么語句就用什么語句,自己會寫最重要,至于那種語句效率高無需理會,少用延時函數(shù)效率最高,還有想要速度快,提高主頻就行,理論上24M主頻比12M快1倍,再怎么優(yōu)化語句,12M主頻快不過24M主頻(指整個程序,不是單獨某個語句)。提高主頻誰都會。
作者: 188610329    時間: 2022-9-30 00:26
himanzj 發(fā)表于 2022-9-29 07:25
左移運算效率高 還是 直接取數(shù) 效率高

就 你舉的 三個例子來講, “左移”效率高,  因為,沒有“左移運算”,編譯的時候,已經(jīng)是結(jié)果了  實際程序運行沒有“左移”這個動作。  而你查表是實打?qū)嵉囊ゲ榈摹?br /> 宏,不是編程,好的宏,應該不是增加MCU額外的工作,而是增加 代碼的易讀性。
否則的話,沒必要寫宏,寫函數(shù)好了。
作者: himanzj    時間: 2022-9-30 14:20
188610329 發(fā)表于 2022-9-30 00:26
就 你舉的 三個例子來講, “左移”效率高,  因為,沒有“左移運算”,編譯的時候,已經(jīng)是結(jié)果了  實際 ...

宏命令中左移運算直接給出結(jié)果,宏命令只是編譯前的字符替換
作者: zmc419    時間: 2022-10-20 11:39
好用,還有別的方法,也在用




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1