C語言常用宏定義的用法介紹
C語言中的宏定義是最常用的組成部分之一,他們在編程時有重要作用,正確應用可以減少很多代碼工作量,但是使用過渡,則會造成可讀性降低。下面小編給大家介紹C語言常用宏定義的用法介紹,歡迎閲讀!
C語言常用宏定義的用法介紹對於宏定義,需要注意以下説明:
(1)宏名一般用大寫;
(2)使用宏可以提高程序的通用性和易讀性,減少不一致性,減少輸入錯誤和便於修改;
(3)預處理是在編譯之前的處理,預處理不做語法檢查;
(4)宏定義末尾沒有分號;//不加;
(5)宏定義自然作用域為從定義開始一直到本文件結尾;
(6)可以用#undef命令提前終止宏定義的'自然作用域;
(7)宏定義可以嵌套;
(8)字符串“”中永遠不包含宏;
(9)宏定義不會分配內存,變量定義分配內存;
(10)宏定義不存在類型問題,它的參數也是無類型的,它僅僅是替換;
(11)宏定義可以帶參數,但需要注意的是每個參數是一個整體,在定義體中要注意括起來。
下面列舉了一些非常常用的宏定義用法:
常數定義
#define PI 3.1415926
防止重複包含
#ifndef __MY_HEAD_H__
#define __MY_HEAD_H__
...//這裏的內容可以保證不被重複包含
#endif
求最大最小值
#define GET_MAX(x, y) (((x) >= (y)) ? (x) : (y))
#define GET_MIN(x, y) (((x) <= (y)) ? (x) : (y))
得到結構體成員的偏移
#define FPOS(type, field) ((unsigned long)&((type *)0)->field)
拼接字節為字
#define MAKEWORD(h, l) (((h)<<8) | (l))
#define MAKEDWORD(h, l) (((h)<<16) | (l))
獲得高、地位字節或者字
#define WORD_LO(w) ((unsigned char)((w) & 0xFF))
#define WORD_HI(w) ((unsigned char)((w) >> 8))
#define DWORD_LO(dw) ((unsigned short)((dw) & 0xFFFF))
#define DWORD_HI(dw) ((unsigned short)((dw) >> 16))
將一個字母轉換為大寫
#define UPCASE(c) (((c) >= 'a' && (c) <= 'z') ? ((c) – 0x20) : (c))
判斷字符是不是10進值的數字
#define DECCHK(c) ((c) >= '0' && (c) <= '9')
判斷字符是不是16進值的數字
#define HEXCHK(c) (((c) >= '0' && (c) <= '9') || ((c) >= 'A' && (c) <= 'F') || ((c) >= 'a' && (c) <= 'f'))
返回數組元素的個數
#define ARR_SIZE(a) (sizeof((a))/sizeof(((a)[0])))