1、 #,为后面的宏形参添加双引号。
例:
#define SINGLESHARP(arg) #arg // 注意:#和arg之间可以有空格,效果一样
SINGLESHARP(singlesharp); <==> "singlesharp";
2、#@,为后面的宏形参添加单引号。
例:
#define SINGLESHARPWITHAT(arg) #@arg // 注意:#和@是一个整体,之间不能有空格,#@和arg之间可以有空格
SINGLESHARPWITHAT($); <==> '$';
3、##,一种分隔连接方式,它的作用是先分隔,然后进行强制连接。
1)分隔的作用类似于空格。在普通的宏定义中,预处理器一般把空格解释成分段标志,对于每一段和前面比较,相同的就被替换,但是这样 做的结果是,被替换段之间存在一些空格。如果不希望出现这些空格,就可以通过添加##来替代空格。另外一些分隔标志包括操作符,比 如+、-、*、/、[、] ...
2)强制连接,就是去掉空格,把两者连接起来。
3)连接##前后两个宏形参的具体过程如下(为方便理解,主观认为如此,实际过程并非如此): 首先用空格代替##,把宏分成几段,每段和宏形参比较,如果是宏形参,就用相应的实参替换,然后去掉所有空格,连接这些段。
例:
#define FOO(arg) my##arg
FOO(abc); <==> myabc;
例:
#define A1(name,type) type name_##type##_type
A1(a1,int); <==> int name_int_type;
例:
#define A2(name,type) type name##_##type##_type
A2(a1,int); <==> int a1_int_type;
注意:##前后可以有若干个空格,效果一样!
例:
#define SINGLESHARP(arg) #arg // 注意:#和arg之间可以有空格,效果一样
SINGLESHARP(singlesharp); <==> "singlesharp";
2、#@,为后面的宏形参添加单引号。
例:
#define SINGLESHARPWITHAT(arg) #@arg // 注意:#和@是一个整体,之间不能有空格,#@和arg之间可以有空格
SINGLESHARPWITHAT($); <==> '$';
3、##,一种分隔连接方式,它的作用是先分隔,然后进行强制连接。
1)分隔的作用类似于空格。在普通的宏定义中,预处理器一般把空格解释成分段标志,对于每一段和前面比较,相同的就被替换,但是这样 做的结果是,被替换段之间存在一些空格。如果不希望出现这些空格,就可以通过添加##来替代空格。另外一些分隔标志包括操作符,比 如+、-、*、/、[、] ...
2)强制连接,就是去掉空格,把两者连接起来。
3)连接##前后两个宏形参的具体过程如下(为方便理解,主观认为如此,实际过程并非如此): 首先用空格代替##,把宏分成几段,每段和宏形参比较,如果是宏形参,就用相应的实参替换,然后去掉所有空格,连接这些段。
例:
#define FOO(arg) my##arg
FOO(abc); <==> myabc;
例:
#define A1(name,type) type name_##type##_type
A1(a1,int); <==> int name_int_type;
例:
#define A2(name,type) type name##_##type##_type
A2(a1,int); <==> int a1_int_type;
注意:##前后可以有若干个空格,效果一样!