使用宏定義可以防止出錯,提高可移植性,可讀性,方便性等。
下面列舉了一些成熟軟件中常用的宏定義。
重新定義一些類型,防止由于各種平臺和編譯器的不同,而產生的類型字節數差異,方便移植:
typedefunsignedcharboolean;/*Booleanvaluetype.*/ typedefunsignedlongintuint32;/*Unsigned32bitvalue*/ typedefunsignedshortuint16;/*Unsigned16bitvalue*/ typedefunsignedcharuint8;/*Unsigned8bitvalue*/ typedefsignedlongintint32;/*Signed32bitvalue*/ typedefsignedshortint16;/*Signed16bitvalue*/ typedefsignedcharint8;/*Signed8bitvalue*/
求最大值和最小值:
#defineMAX(x,y)(((x)>(y))?(x):(y)) #defineMIN(x,y)(((x)(y))???(x)?:?(y)?)
得到一個field在結構體(struct)中的偏移量:
#defineFPOS(type,field) /*lint-e545*/((dword)&((type*)0)->field)/*lint+e545*/
得到一個結構體中field所占用的字節數:
#defineFSIZ(type,field)sizeof(((type*)0)->field)
按照LSB格式把兩個字節轉化為一個Word:
1#defineFLIPW(ray)((((word)(ray)[0])*256)+(ray)[1])
按照LSB格式把一個Word轉化為兩個字節:
#defineFLOPW(ray,val) (ray)[0]=((val)/256); (ray)[1]=((val)&0xFF)
得到一個變量的地址(word寬度):
#defineB_PTR(var)((byte*)(void*)&(var)) #defineW_PTR(var)((word*)(void*)&(var))
得到一個字的高位和低位字節:
#defineWORD_LO(xxx)((byte)((word)(xxx)&255)) #defineWORD_HI(xxx)((byte)((word)(xxx)>>8))
將一個字母轉換為大寫:
#defineUPCASE(c)(((c)>='a'&&(c)<=?'z')???((c)?-?0x20)?:?(c)?)
判斷字符是不是10進制的數字:
#define DECCHK( c ) ((c) >= '0' && (c) <= '9')
判斷字符是不是16進制的數字:
#defineHEXCHK(c)(((c)>='0'&&(c)<=?'9')?|| ((c)?>='A'&&(c)<=?'F')?|| ((c)?>='a'&&(c)<=?'f')?)
防止一個頭文件被重復包含:
#ifndefCOMDEF_H #defineCOMDEF_H //頭文件內容 #endif
防止溢出的一個方法:
#defineINC_SAT(val)(val=((val)+1>(val))?(val)+1:(val))
返回數組元素的個數:
#defineARR_SIZE(a)(sizeof((a))/sizeof((a[0])))
審核編輯:劉清
-
存儲器
+關注
關注
38文章
7452瀏覽量
163606 -
C語言
+關注
關注
180文章
7598瀏覽量
136199 -
LSB算法
+關注
關注
0文章
7瀏覽量
5805
原文標題:寫好C語言,漂亮的宏定義很重要!
文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論