歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

C語言宏定義的連接符##和#轉字符串

c語言宏定義的連接符有哪些

[此問題的推薦答案]

(一)宏定義中的## 連接符與# 符

## 連接符號由兩個井號組成,其功能是在帶參數的宏定義中將兩個子串(token)聯接起來,從而形成一個新的子串。但它不可以是第一個或者最後一個子串。所謂的子串(token)就是指編譯器能夠識別的最小語法單元。具體的定義在編譯原理裡有詳盡的解釋,但不知道也無所謂。同時值得注意的是#符是把傳遞過來的參數當成字符串進行替代。下面來看看它們是怎樣工作的。這是MSDN上的一個例子。

假設程序中已經定義了這樣一個帶參數的宏:

#define paster( n ) printf( "token" #n " = %d", token##n )

同時又定義了一個整形變量:

int token9 = 9;

現在在主程序中以下面的方式調用這個宏:

paster( 9 );

那麼在編譯時,上面的這句話被擴展為:

printf( "token" "9" " = %d", token9 );

注意到在這個例子中,paster(9);中的這個”9”被原封不動的當成了一個字符串,與”token”連接在了一起,從而成為了token9。而#n也被”9”所替代。

可想而知,上面程序運行的結果就是在屏幕上打印出token9=9

(二)"/"與一個較長占多行的宏

宏定義中允許包含兩行以上命令的情形,此時必須在最右邊加上"/"且該行"/"後不能再有任何字符,連注釋部分都不能有,下面的每行最後的一定要是"/","/"後面加一個空格都會報錯,更不能跟注釋。

#define exchange(a,b) {/

int t;/

t=a;/

a=b;/

b=t;/

}

經常使用_T()宏,它是怎麼來的?用VA看了一下,原來_T是__T

#define _T(x)       __T(x)

再看看__T

在tchar.h中

#ifdef  _UNICODE

#define __T(x)      L ## x

#else

#define __T(x)      x

#endif

那麼,這個##是什麼呢?原來它是一個連接符,將##左右兩邊的表達式連接成一個.比如,在_UNICODE環境下,

_T(“Unicode“) == L“Unicode“

不過需要注意的是,宏是由編譯器在編譯階段識別的,所以不能指望程序運行時起到連接作用.比如:

int A0, A1, A2, A3;

for (int i = 0; i < 4; i++)

{

A##i = i;

}

這種代碼就無法編譯了.

Copyright © Linux教程網 All Rights Reserved