C中的預處理宏
宏定義就屬于預處理命令的一種。那么,什么是宏呢?
宏:c語言標準允許在程序中用一個標識符來表示一個字符串。標識符就是宏名。
宏替換:宏替換就是宏定義。在編譯預處理中,將程序中所有的宏名用相應的字符串來替換,這個過程稱為宏替換。
宏分為兩種:
1、無參數宏?? #define 標識符 字符串
2、帶參數宏?? #define 標識符(形參表) 字符串
因為無參數宏比較簡單,所以重點說一下帶參數宏。
有參宏定義中#的用法
#define?STR(str)?#str
#用于把宏定義中的參數兩端加上字符串的""
比如,這里STR(my#name)會被替換成"my#name"
一般由任意字符都可以做形參,但以下情況會出錯:
STR())這樣,編譯器不會把“)”當成STR()的參數。
STR(,)同上,編譯器不會把“,”當成STR的參數。
STR(A,B)如果實參過多,則編譯器會把多余的參數舍去。
STR((A,B))會被解讀為實參為:(A,B),而不是被解讀為兩個實參,第一個是(A第二個是B)。
一個預處理宏的例子:
# define PRINT(STR,VAR) cout<
跟在宏名后面的括號中的參數會被閉括號后面的所有代碼替代。只要在調用宏的地方,預處理程序就刪除名字PRINT并替換代碼,所以使用宏名時編譯器不會報告任何錯誤信息,它并不對參數做任何類型檢查。
有參宏定義中##的用法
#define?WIDE(str)?L##str
則會將形參str的前面加上L
比如:WIDE("abc")就會被替換成L"abc"
如果有#define?FUN(a,b)?vo##a##b()
那么FUN(id?ma,in)會被替換成void?main()
另一個例子:
# define P(EX) cout<
其中的“#”被稱為:字符串化的預處理特征,其作用是獲得任何一個表達式并把它轉換為一個字符數組。
多行宏定義:
#define?doit(m,n)?for(int?i=0;i
{\
m+=i;\
}