您的位置:首页 > 运维架构 > Linux

linux内核源码分析——linux/stringify.h

2014-10-24 08:54 246 查看
#ifndef __LINUX_STRINGIFY_H
#define __LINUX_STRINGIFY_H

/* Indirect stringification.  Doing two levels allows the parameter to be a
* macro itself.  For example, compile with -DFOO=bar, __stringify(FOO)
* converts to "bar".
*/

#define __stringify_1(x)	#x
#define __stringify(x)		__stringify_1(x)

#endif	/* !__LINUX_STRINGIFY_H */



__stringify(x)定义了一个宏,根据C语言中#的用法可知,这是一个将参数字符串化的宏,如

printf(__stringify(hello));
相当于
printf("hello");


代码中又将__stringify(x)包装了一层,之所以两次宏定义,文档注释中也写得清楚,是为了能提供参数的宏嵌套。C语言中的宏嵌套,预编译时一般是先展开参数,再展开函数,而当遇到#时,则不展开参数,只展开函数。因此,如果

#define __stringify(x)  #x
#define FOO bar
printf(__stringify(FOO));


相当于

printf("FOO");


经过两次宏定义

#define __stringify_1(x) #x
#define __stringify(x)  __stringify_1(x)
#define FOO bar
printf(__stringify(FOO))


先展开如下

printf(__stringify(bar));
printf(__stringify_1(bar));
再展开为
printf("bar");


刚开始写博客,就写这一个简单的头文件吧。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  linux内核 源码 c语言