Chinaunix首页 | 论坛 | 博客
  • 博客访问: 340257
  • 博文数量: 59
  • 博客积分: 2000
  • 博客等级: 大尉
  • 技术积分: 646
  • 用 户 组: 普通用户
  • 注册时间: 2008-07-14 12:09
文章分类

全部博文(59)

文章存档

2009年(2)

2008年(57)

我的朋友

分类: C/C++

2008-07-14 17:54:19

宏在C/C++程序中使用的非常之多,是代码自动化生成的利器,但在跟踪调试时宏却又成了负担,宏展开的代码很多时候都出人意料。把展开后的宏输出,是分析宏的好方法。
下面先介绍宏的“#”操作符
define MACRO_(x)  #x
这个MACRO_宏就是把参数x转化为字符串,看下面的例子
1 #define    MACRO_(x)    #x
2 int main(int argc ,char* argv[] )
3 {
4     printf("%s",MACRO_(printf));
5     return 0;
6 }

输出:
printf
如果参数x是个宏呢,那么输出的会是什么呢,是宏的名字还是展开后的宏代码
1 #define    MACRO_(x)    #x
2 #define HELLO        "Hello World"
3 int main(int argc ,char* argv[] )
4 {
5     printf("%s",MACRO_(HELLO));
6     return 0;
7 }
上面这段代码是输出:HELLO,还是Hello World呢?
如果是Hello World那么我们的目的也就达到了,输出了展开后的宏代码
但事与愿违,上面代码输出的是HELLO,因为#操作符会把后面的参数强制转为字符串,遇到宏是不会展开的。
这个方法失败,既然#可以把它后面的参数变为字符串,那么我们必须保证在宏遇到#操作符之前就是展开的。这样我们还需要定义一个辅助的宏,用来用来让参数宏展开。
1 #define    MACRO_(x)        #x
2 #define HELLO            "Hello World"
3 #define    SHOWMACOR(mac)    MACRO_(mac)
4 int main(int argc ,char* argv[] )
5 {
6     printf("%s\n",SHOWMACOR(HELLO));
7     return 0;
8 }
这样输出的就是展开后的:"Hello World"了
我们来分析SHOWMACOR展开的过程
第一步变为:MACRO_(HELLO)
 上面的表达式中没有出现#,那么先是括号中的HELLO展开
第二步变为:MACRO_("Hello World")
最后MACRO_展开变为:#"Hello World"
所以输出为:"Hello World"


自:
http://www.cppblog.com/loky/archive/2008/04/08/46503.html
阅读(848) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

lizeliang.linux2008-08-16 20:36:37

宏很强大,也很灵活,内核中到处都充满了宏的身影,说到底还是C语言的基础。