C C巨集定義中 連線符與 符的含義

2021-06-16 17:14:01 字數 1013 閱讀 1913

1.

2.

3,

## 連線符號由兩個井號組成,其功能是在帶引數的巨集定義中將兩個子串(token)聯接起來,從而形成乙個新的子串。但它不可

以是第乙個或者最後乙個子串。所謂的子串(token)就是指編譯器能夠識別的最小語法單元。具體的定義在編譯原理裡有詳盡的

解釋,但不知道也無所謂。同時值得注意的是#連線符是把傳遞過來的引數當成字串進行替代。下面來看看它們是怎樣工作

的。這是msdn上的乙個例子。

假設程式中已經定義了這樣乙個帶引數的巨集:

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

同時又定義了乙個整形變數:

int token9 = 9;

現在在主程式中以下面的方式呼叫這個巨集:

paster( 9 );

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

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

詳細解說:#n 相當於 「n」, token##n 相當於token9,須注意##不能當成兩個#,他們意義是不同的。

注意到在這個例子中,paster(9);中的這個」9」被原封不動的當成了乙個字串,與」token」連線在了一起,從而成為了

token9。而#n也被」9」所替代。

可想而知,上面程式執行的結果就是在螢幕上列印出token9=9

注意##和#的使用場合,不能亂用

# —— 字串 

##——連線兩個引數

例項:

#include
using

namespace std;

#define test(pid) (cout

巨集定義中的 連線符與 符

連線符與 符 連線符號由兩個井號組成,其功能是在帶引數的巨集定義中將兩個子串 token 聯接起來,從而形成乙個新的子串。但它不可以是第乙個或者最後乙個子串。所謂的子串 token 就是指編譯器能夠識別的最小語法單元。具體的定義在編譯原理裡有詳盡的解釋,但不知道也無所謂。同時值得注意的是 符是把傳遞...

巨集定義中的 連線符與 符

連線符與 符 連線符號由兩個井號組成,其功能是在帶引數的巨集定義中將兩個子串 token 聯接起來,從而形成乙個新的子串。但它不可以是第乙個或者最後乙個子串。所謂的子串 token 就是指編譯器能夠識別的最小語法單元。具體的定義在編譯原理裡有詳盡的解釋,但不知道也無所謂。同時值得注意的是 符是把傳遞...

巨集定義中的 連線符與 符

連線符與 符 連線符號由兩個井號組成,其功能是在帶引數的巨集定義中將兩個子串 token 聯接起來,從而形成乙個新的子串。但它不可以是第乙個或者最後乙個子串。所謂的子串 token 就是指編譯器能夠識別的最小語法單元。具體的定義在編譯原理裡有詳盡的解釋,但不知道也無所謂。同時值得注意的是 符是把傳遞...