宏定义中#等的用法

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

C语言宏定义中"#","#@"和"##"的用法一、引言

#define macro(a)#a

#define macro2(a,b)a##b

#define macro3(a,b,c)a##b##c

#a,表示a不再是一个变量,而变成了字符串"a"

##表示连接,a##b,表示输入的参数名为ab,a##b##c同理,代表变量名为:abc

测试例子:

int x=3;

int y=4;

int xy=10;

int xyz=20;

CString str;

OutputDebugString(macro(x));

str.Format("%d",macro2(x,y));

OutputDebugString(str);

str.Format("%d",macro3(x,y,z));

OutputDebugString(str);

输出结果为:

x

10

20

第一个为x,marco(x),x变成了"x"字符串

第二个为10,macro(x,y),就是变量xy

第三个为20,macro(x,y,z),就是变量xyz

二、一般用法

#把宏参数变为一个字符串,#@把宏参数变为一个字符,##把两个宏参数贴合在一起。

#include

#include

#define STR(s)#s//#与参数之间可以有空格

#define TOCHAR(c)#@c

#define CONS(a,b)int(a##e##b)//##与参数之间可以有空格

int main(void)

{

printf(STR(pele));//输出字符串"pele"

printf("%c\n",TOCHAR(z));//输出字符z

printf("%d\n",CONS(2,3));//2e3输出:2000

return0;

}

三、当宏参数是另一个宏的时候

需要注意的是凡宏定义里有用'#'或'##'的地方宏参数是不会再展开的。

#define A(2)

#define STR(s)#s

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

printf("int max:%s\n",STR(INT_MAX));

这行会被展开为:

printf("int max:%s\n","INT_MAX");

printf("%s\n",CONS(A,A));

这一行被展开为:

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:0x7fffffff

STR(INT_MAX)-->_STR(0x7fffffff)-->"0x7fffffff"

printf("%d\n",CONS(A,A));

输出为:200

CONS(A,A)-->_CONS((2),(2))-->int((2)e(2))

以下为Minix3操作系统相关的源代码:

#ifdef_ANSI

#define__str(x)#x

#define__xstr(x)__str(x)//转换宏

_PROTOTYPE(void__bad_assertion,(const char*_mess));

#define assert(expr)((expr)?(void)0:\

__bad_assertion("Assertion\""#expr\

"\"failed,file"__xstr(__FILE__)\

",line"__xstr(__LINE__)"\n"))

四、"#"和"##"的一些应用特例

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){a,#a}

enum IDD{OPEN,CLOSE};

typedef struct MSG

{

IDD id;

const char*msg;

}MSG;

MSG_msg[]={FILL(OPEN),FILL(CLOSE)};

相当于:

相关文档
最新文档