python宏替换_#和##在宏替换中的作用
#include
#define f(a,b) a##b
#define g(a)? #a
#define h(a) g(a)
int main()
{
printf("%s/n",h(f(1,2)));
printf("%s/n",g(f(1,2)));
return 0;
}
首先需要了解#和##的意義。
#? 將右邊的參數(shù)做整體的字符串替換。
#define g(a)? #a
則g(hello world) à hello world; g(sleep(1)) à sleep(1)
對(duì)于#的參數(shù),即便是另一個(gè)宏,也不展開,仍然作為字符串字面信息輸出。
所以,g(f(1,2)) à f(1,2)
對(duì)于h(f(1,2)),由于h(a)是非#或##的普通宏,需要先宏展開其參數(shù)a,即展開f(1,2)為12,則h(a) 宏替換為h(12),進(jìn)而宏替換為g(12), 進(jìn)而宏替換為12
## 將左右兩邊的參數(shù)做整體的字符串拼接替換。
#define f(a,b) a##b
則f(1,2) à 12, f(i,1) à i1
同#,對(duì)于##的參數(shù),即便是另一個(gè)宏,也不展開,仍然作為字符串字面信息輸出。
此外,有一個(gè)限制是,經(jīng)過##替換后的內(nèi)容必須能夠作為一個(gè)合法的變量。
以上f(i,1) à i1中,如果程序中沒有i1的定義,或者通過f(1,i)構(gòu)成1i,則即便是通過了宏替換,也不能編譯通過。
--------------------------------------------------------------------------------
日常實(shí)踐中,##是常用的替換。尤其在通過C的函數(shù)指針來模擬動(dòng)態(tài)綁定時(shí)大有用處。
下面是從stackoverflow(具體id記不清了)上摘取的一個(gè)例子。
struct command
{
char *name;
void (*function) (void);
};
struct command commands[] =
{
{ "quit", quit_command },
{ "help", help_command },
...
};
構(gòu)造一個(gè)這樣的commands數(shù)組,是為了在后續(xù)的設(shè)計(jì)中,可以通過交互式的字符串輸入,來動(dòng)態(tài)地執(zhí)行相應(yīng)的函數(shù)。字符串自身作為前綴,”_command”作為后綴。
手工構(gòu)造這樣第一個(gè)commands數(shù)組顯得非常冗余,還容易造成不必要的拼寫錯(cuò)誤。下面來看看這個(gè)宏替換版本。
#define COMMAND(NAME)? { #NAME, NAME ## _command }
struct command commands[] =
{
COMMAND (quit),
COMMAND (help),
...
};
清晰了很多!
總結(jié)
以上是生活随笔為你收集整理的python宏替换_#和##在宏替换中的作用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python实现滑块验证功能_pytho
- 下一篇: python3 写文件时指定文件名_Py