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内核2.6.14源码分析-双向循环链表代码分析
- s3c2410 RTC驱动框架linux内核源码分析
- Linux内核源码分析--内核启动命令行的传递过程(Linux-3.0 ARMv7)
- linux-3.2.36内核启动4-setup_arch中的内存初始化3(arm平台 bootmem_init源码分析)
- Linux内核源码分析--内核启动之(1)zImage自解压过程(Linux-3.0 ARMv7)
- Linux内核源码分析(1)——compiler.h分析(2)
- Linux内核源码分析——compiler.h分析
- Linux内核源码分析方法
- Linux内核源码分析--内核启动命令行的传递过程(Linux-3.0 ARMv7)
- Linux内核源码分析--内核启动命令行的传递过程(Linux-3.0 ARMv7)
- linux2.6源码分析之解压内核映像 head.s
- [精华]]Linux内核2.6.14源码分析-双向循环链表代码分析(转)
- Linux内核源码分析(1)——compiler.h分析(3)
- linux源码分析--内核启动之(2)Image内核启动(汇编部分)
- Linux内核源码分析--内核启动命令行的传递过程(Linux-3.0 ARMv7)
- arm-linux源码分析之解压内核映像
- 关于linux2.6.32-2内核源码分析
- Linux内核2.6.14源码分析-双向循环链表代码分析(巨详细)
- Linux内核源码分析--内核启动命令行的传递过程(Linux-3.0 ARMv7)
- Linux内核源码分析--内核启动之(1)zImage自解压过程(Linux-3.0 ARMv7)