C語言巨集定義中 用法

2021-09-30 06:11:36 字數 2712 閱讀 1270

c語言巨集定義中#用法

巨集中"#"和"##"的用法

一、一般用法

我們使用#把巨集引數變為乙個字串,用##把兩個巨集引數貼合在一起.

用法:#i nclude

#i nclude

using namespace std;

#define str(s)     #s

#define cons(a,b)  int(a##e##b)

int main()

二、當巨集引數是另乙個巨集的時候

需要注意的是凡巨集定義裡有用'#'或'##'的地方巨集引數是不會再展開.

1, 非'#'和'##'的情況

#define tow      (2)

#define mul(a,b) (a*b)

printf("%d*%d=%d/n", tow, tow, mul(tow,tow));

這行的巨集會被展開為:

printf("%d*%d=%d/n", (2), (2), ((2)*(2)));

mul裡的引數tow會被展開為(2).

2, 當有'#'或'##'的時候

#define a          (2)

#define str(s)     #s

#define cons(a,b)  int(a##e##b)

printf("int max: %s/n",  str(int_max));    // int_max #i nclude

這行會被展開為:

printf("int max: %s/n", "int_max");

printf("%s/n", cons(a, a));               // compile error 

這一行則是:

printf("%s/n", int(aea));

int_max和a都不會再被展開, 然而解決這個問題的方法很簡單. 加多一層中間轉換巨集.

加這層巨集的用意是把所有巨集的引數在這層裡全部展開, 那麼在轉換巨集裡的那乙個巨集(_str)就能得到正確的巨集引數.

#define a           (2)

#define _str(s)     #s

#define str(s)      _str(s)          // 轉換巨集

#define _cons(a,b)  int(a##e##b)

#define cons(a,b)   _cons(a,b)       // 轉換巨集

printf("int max: %s/n", str(int_max));          // int_max,int型的最大值,為乙個變數 #i nclude

輸出為: int max: 0x7fffffff

str(int_max) -->  _str(0x7fffffff) 然後再轉換成字串;

printf("%d/n", cons(a, a));

輸出為:200

cons(a, a)  -->  _cons((2), (2))  --> int((2)e(2))

三、'#'和'##'的一些應用特例

1、合併匿名變數名

#define  ___anonymous1(type, var, line)  type  var##line

#define  __anonymous0(type, line)  ___anonymous1(type, _anonymous, line)

#define  anonymous(type)  __anonymous0(type, __line__)

例:anonymous(static int);  即: static int _anonymous70;  70表示該行行號;

第一層:anonymous(static int);  -->  __anonymous0(static int, __line__);

第二層:                        -->  ___anonymous1(static int, _anonymous, 70);

第三層:                        -->  static int  _anonymous70;

即每次只能解開當前層的巨集,所以__line__在第二層才能被解開;

2、填充結構

#define  fill(a)   

enum idd;

typedef struct msgmsg;

msg _msg = ;

相當於:

msg _msg = , };

3、記錄檔名

#define  _get_file_name(f)   #f

#define  get_file_name(f)    _get_file_name(f)

static char  file_name = get_file_name(__file__);

4、得到乙個數值型別所對應的字串緩衝大小

#define  _type_buf_size(type)  sizeof #type

#define  type_buf_size(type)   _type_buf_size(type)

char  buf[type_buf_size(int_max)];

-->  char  buf[_type_buf_size(0x7fffffff)];

-->  char  buf[sizeof "0x7fffffff"];

這裡相當於:

char  buf[11];

c語言解除巨集定義 C語言中巨集定義的用法

說到巨集定義,我們應該先了解什麼是預處理指令,相信大家並不會陌生,之前我們程式設計時,程式的開頭 include指令,define指令都是預處理指令,它能使我們的編譯更加的高效,便捷,因此c語言中是允許使用者自己加入一些特定的預處理指令的。一,不帶引數的巨集定義 不帶引數的巨集定義是比較簡單的,就是...

C語言巨集定義中 , 和 的用法

1 一般用法 把巨集引數變為乙個字串,把巨集引數變為乙個字元,把兩個巨集引數貼合在一起。include include define str s s 與引數之間可以有空格 define tochar c c define cons a,b int a e b 與引數之間可以有空格 int main ...

C語言 巨集定義的用法總結

define 函式 define debug x x x 如上所示,用於對數值表示式進行求值的巨集定義都應該用這種方式加上括號,避免在使用巨集時由於引數中的操作等或鄰近操作符之間不可預料的相互作用。define 替換 1.在呼叫巨集時,首先對引數進行檢查,看看是否包含任何由 define 定義的符號...